IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> iframe 无刷新图片上传图片 -> 正文阅读

[JavaScript知识库]iframe 无刷新图片上传图片

效果图:
在这里插入图片描述

使用iframe实现无刷新上传图片首先需要在iframe指定下form,action指定为要提交的地址,注意form表单是不能嵌套的
在这里插入图片描述
后台:
在这里插入图片描述
在这里插入图片描述
js:
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
代码展示:

前端:

{% extends "common/layout_main.html" %}
{% block content %}
<div class="row  border-bottom">
    <div class="col-lg-12">
        <div class="tab_title">
            <ul class="nav nav-pills">
                <li class="current">
                    <a href="{{ buildUrl('/food/index') }}">美食列表</a>
                </li>
                <li>
                    <a href="{{ buildUrl('/food/cat') }}">分类列表</a>
                </li>
            </ul>
        </div>
    </div>
</div>
<div class="row mg-t20 wrap_food_set" style="">
    <div class="col-lg-12" style="">
        <h2 class="text-center">设置</h2>
        <div class="form-horizontal m-t" style="">
            <div class="form-group">
                <label class="col-lg-2 control-label">分类:</label>
                <div class="col-lg-10">
                    <select name="cat_id" class="form-control select2-hidden-accessible select2-container" tabindex="-1"
                            aria-hidden="true">
                        <option value="0">请选择分类</option>
                        <option value="8">111</option>
                        <option value="8">川菜</option>
                        <option value="8">粤菜</option>
                        <option value="8">湘菜</option>
                    </select>
                </div>
            </div>
            <div class="hr-line-dashed"></div>
            <div class="form-group">
                <label class="col-lg-2 control-label">名称:</label>
                <div class="col-lg-10">
                    <input type="text" class="form-control" placeholder="请输入名称" name="name" value="">
                </div>
            </div>
            <div class="hr-line-dashed"></div>
            <div class="form-group">
                <label class="col-lg-2 control-label">价格:</label>
                <div class="col-lg-10">
                    <input type="text" class="form-control" placeholder="请输入售价" name="price" value="">
                </div>
            </div>
            <div class="hr-line-dashed"></div>
            <div class="form-group">
                <label class="col-lg-2 control-label">封面图:</label>
                <div class="col-lg-10">
                    <form class="upload_pic_wrap" target="upload_file" enctype="multipart/form-data" method="POST" action="{{ buildUrl('/upload/pic') }}">
                        <div class="upload_wrap pull-left">
                            <i class="fa fa-upload fa-2x"></i>
                            <input type="file" name="pic" accept="image/png, image/jpeg, image/jpg,image/gif">
                        </div>
                    </form>
                </div>
            </div>
            <div class="hr-line-dashed"></div>
            <div class="form-group" style="">
                <label class="col-lg-2 control-label">描述:</label>
                <div class="col-lg-10">
                    <textarea  id="editor"  name="summary" style="height: 300px;"></textarea>
                </div>
            </div>
            <div class="hr-line-dashed"></div>
            <div class="form-group">
                <label class="col-lg-2 control-label">库存:</label>
                <div class="col-lg-2">
                    <input type="text" name="stock" class="form-control" value="1">
                </div>
            </div>
            <div class="hr-line-dashed"></div>
            <div class="form-group">
                <label class="col-lg-2 control-label">标签:</label>
                <div class="col-lg-10">
                    <input type="text" class="form-control" name="tags"  value="">
                </div>
            </div>
            <div class="hr-line-dashed"></div>
            <div class="form-group">
                <div class="col-lg-4 col-lg-offset-2">
                    <input type="hidden" name="id" value="0">
                    <button class="btn btn-w-m btn-outline btn-primary save">保存</button>
                </div>
            </div>
        </div>
    </div>
</div>
<iframe name="upload_file" class="hidden"> </iframe>


{% endblock %}
{% block css %}
    {#    导入 select2#}
    <link href="{{ buildStaticUrl('/plugins/select2/select2.min.css')}}" rel="stylesheet">
    {#    导入 tagsinput#}
    <link href="{{ buildStaticUrl('/plugins/tagsinput/jquery.tagsinput.css ')}}" rel="stylesheet">

{% endblock %}
{% block js %}



{#    select2 导入js#}
{#    <script src="{{ buildStaticUrl('/plugins/select2/jquery.select2.js ')}}"></script>#}
    <script src="{{ buildStaticUrl('/plugins/select2/select2.pinyin.js')}}"></script>
{#    <script src="{{ buildStaticUrl('/plugins/select2/zh-CN.js ')}}"></script>#}
{#    导入 tagsinput#}
    <script src="{{ buildStaticUrl('/plugins/tagsinput/jquery.tagsinput.min.js ')}}"></script>




    {#ueditor富文本编辑器#}
    <script src="{{ buildStaticUrl('/plugins/ueditor/ueditor.config.js ')}}"></script>
    <script src="{{ buildStaticUrl('/plugins/ueditor/ueditor.all.js ')}}"></script>
    <script src="{{ buildStaticUrl('/plugins/ueditor/lang/zh-cn/zh-cn.js ')}}"></script>
    <script src="{{ buildStaticUrl('/js/food/set.js ')}}"></script>
{#    <script src="{{ buildStaticUrl('/js/jquery-2.1.1.js ')}}"></script>#}


{% endblock %}

后台:

# 封面图片处理
@route_upload.route("/pic",methods=["POST","GET"])
def upload_pic():
    files_pic=request.files
    # 判断用户是否上传文件
    files_pic= files_pic["pic"] if "pic" in files_pic else None
    # 使用ifarm子窗口调用父窗口里的方法
    callback_target="window.parent.upload"
    if files_pic is None:
        return "<scrpit type='text/javascript'>{0}.error('{1}')</scrpit>".format(callback_target,"图片长传失败")
    # 处理文件
    ret=UploadService.UploadByFile(files_pic)

    if ret["code"] !=200:
        return "<script type='text/javascript'>{0}.error('{1}')</script>".format(callback_target,"图片长传失败")
    return "<script type='text/javascript'>{0}.success('{1}')</script>".format(callback_target,ret["data"]["file_key"])

图片处理代码:

import os,stat
import uuid
from werkzeug.utils import secure_filename

from application import app, db
from common.libs.Helper import getGreated_date
from common.models.Images import Image


class UploadService:
    @staticmethod
    def UploadByFile(file):
        config_upload=app.config["UPLOAD"]

        resp={"code":200,"msg":"操作成功","data":{}}

        # 安全的获取文件名
        filename=secure_filename(file.filename)
        # 获得后缀名,[0]文件名,
        ext=filename.rsplit('.',1)[1]

        # 判断后缀名是否在配置中
        if not ext in config_upload['ext']:
            resp["code"]=-1
            resp["msg"]="不允许的扩展类型文件"
            return resp

        root_path=app.root_path.replace("\\","/")+config_upload['prefix_path']
        print(app.root_path)
        file_dir=getGreated_date()
        save_dir=root_path+"/"+file_dir
        if not os.path.exists(save_dir):
            os.mkdir(save_dir)
            os.chmod(save_dir,stat.S_IRWXU | stat.S_IRGRP |stat.S_IRWXO)

        file_name=str(uuid.uuid4()).replace("_","")+"."+ext
        file.save("{0}/{1}".format(save_dir,file_name))
        module_image=Image()
        module_image.file_key=file_dir+"/"+file_name
        module_image.created_time=getGreated_date()
        db.session.add(module_image)
        try:
            db.session.commit()
        except Exception as e:
            resp["code"] = -1
            resp["msg"] = "服务器异常,保存图片失败!"
            return resp

        resp["data"]={
            "file_key":file_dir+"/"+file_name
        }
        return resp

JS:

var upload = {
    error: function (msg) {
        common_ops.alert(msg);
    },
    success: function (file_key) {

        if (!file_key) {

            return;
        }

        var html = '<img src="' + common_ops.buildPicUrl(file_key) + '"/>'
                + '<span class="fa fa-times-circle del del_image" data="' + file_key + '"></span>';

        if ($(".upload_pic_wrap .pic-each").size() > 0) {

            $(".upload_pic_wrap .pic-each").html(html);
        } else {
            $(".upload_pic_wrap").append('<span class="pic-each">' + html + '</span>');
        }
        food_set.delete_img();
    }
};
var food_set={
    init:function () {
        this.eventBind();
        this.initEditor();
    },
    eventBind:function () {
        $(".wrap_food_set .upload_pic_wrap input[name=pic]").change(function () {

              $(".wrap_food_set .upload_pic_wrap").submit();

        });

        $(".wrap_food_set select[name=cat_id]").select2({
            language: "zh-CN",
            width: '100%'
        });

        $(".wrap_food_set input[name=tags]").tagsInput({
            width:'auto',
            height: 20
        });

    },

    initEditor:function () {
        var that=this;
        that.ue = UE.getEditor('editor', {
            toolbars: [
                ['undo', 'redo', '|',
                    'bold', 'italic', 'underline', 'strikethrough', 'removeformat', 'formatmatch', 'autotypeset', 'blockquote', 'pasteplain', '|', 'forecolor', 'backcolor', 'insertorderedlist', 'insertunorderedlist', 'selectall', '|', 'rowspacingtop', 'rowspacingbottom', 'lineheight'],
                ['customstyle', 'paragraph', 'fontfamily', 'fontsize', '|',
                    'directionalityltr', 'directionalityrtl', 'indent', '|',
                    'justifyleft', 'justifycenter', 'justifyright', 'justifyjustify', '|', 'touppercase', 'tolowercase', '|',
                    'link', 'unlink'],
                ['imagenone', 'imageleft', 'imageright', 'imagecenter', '|',
                    'insertimage', 'insertvideo', '|',
                    'horizontal', 'spechars', '|', 'inserttable', 'deletetable', 'insertparagraphbeforetable', 'insertrow', 'deleterow', 'insertcol', 'deletecol', 'mergecells', 'mergeright', 'mergedown', 'splittocells', 'splittorows', 'splittocols']

            ],
            //设置多久自动保存
            enableAutoSave: true,
            saveInterval: 60000,
            //关闭元素路径
            elementPathEnabled: false,
            zIndex: 4,
            //图片上传的图片地址
            serverUrl: common_ops.buildUrl('/upload/ueditor')
        });
    },

    delete_img:function () {
        $(".upload_pic_wrap .del_image").unbind().click(function () {
            $(this).parent().remove();
        })
    }
};

$(document).ready(function () {
   food_set.init();
   $('.singleSelect').select2();

});
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-24 00:26:06  更:2022-03-24 00:27:20 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:49:29-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码