ssi-uploader上传图片插件,点击选择文件按钮自动提交表单解决办法

先介绍一下这款插件,然后再谈使用中可能遇到的问题

ssi-uploader是一个JQuery的图片上传插件,界面比较美观

github地址:https://github.com/ssbeefeater/ssi-uploader

演示地址:http://ssbeefeater.github.io/#ssi-uploader/examples

使用文档:http://ssbeefeater.github.io/#ssi-uploader/documentation

这里就不说明怎么使用了,github上面提供有,官网文档上面也有

本博文主要说两个问题,也是我使用时碰到的,后续碰到问题在来补充

1、中文显示问题(虽然官方说支持中文,但在js文件源码中并没有写这块儿的代码)

2、当点击选择文件时,自动提交表单<form>的action地址

问题1解决办法:

使用文本编辑器(或任何一款代码编辑器)打开ssi-uploader.js文件,滑动至文档几行最后,会看到只有en英文,和希腊文,

在locale添加如下代码,注意添加逗号。

,zh_CN: {
            success: ‘成功‘,
            sucUpload: ‘上传成功‘,
            chooseFiles: ‘选择文件‘,
            uploadFailed: ‘上传失败‘,
            serverError: ‘服务器内部错误‘,
            error: ‘错误‘,
            abort: ‘终止‘,
            aborted: ‘已经终止‘,
            files: ‘文件‘,
            upload: ‘上传‘,
            clear: ‘清空‘,
            drag: ‘将文件拖放到这里‘,
            sizeError: ‘文件$1,超过限制大小$2‘,// $1=file name ,$2=max ie( example.jpg has has exceed the size limit of 2mb)
            extError: ‘不支持$1类型的文件‘,//$1=file extension ie(exe files are not supported)
            someErrorsOccurred: ‘发生了一些错误‘
        }

然后在使用时这样即可,注意第五行

$(‘#ssi-upload‘).ssi_uploader({
        url: ‘#‘,
        preview: false,
        maxNumberOfFiles: 1,
        locale: "zh_CN",
        allowed: [‘jpg‘, ‘gif‘, ‘txt‘, ‘png‘, ‘pdf‘]
    });

  

问题2解决办法:

根本原因我没有找到,不过我找到一种方法可以解决

首先在html文档中,给input添加属性data-validate="required:" ,即不可无值

<input data-validate="required:" type="file" multiple id="ssi-upload" />

然后修改ssi-uploader.js文件的67行,将

$input.on(‘change‘, function () { //choose files
            thisS.toUploadFiles(this.files);
            $input.val(‘‘);
        });

  改为

$input.on(‘change‘, function () { //choose files
            thisS.toUploadFiles(this.files);
            $input.val(‘a‘);
        });

网上这个问题信息比较少,所以希望对大家有帮助,后续遇到问题还会补充

转载请注明地址谢谢

时间: 2024-10-08 06:17:05

ssi-uploader上传图片插件,点击选择文件按钮自动提交表单解决办法的相关文章

sublime text2 打开包含中文的文件会自动追加.dump后缀解决办法

用sublime text2 打开.c, .h,.txt等文件会自动追加一个.dump后缀,這样在打开.c,.h等文件时无法正常识别,从而无法正常进行语法着色,网上说是因为安装了GBK Encoding Support 插件的问题,于是就删除这个插件,发现再打开不会自动加.dump后缀了,但是遇到中文就乱码了, 因为GBK-.,这个插件就是解决中文乱码用的,那怎么办呢? 其实只要重新保存一下就可以了,比如我打开一个A.h文件,这个里有中文注释, 第一次打开时因为有中文所以sublime text

文件上传控件值发生变化后自动提交表单

当文件上传控件发生变化后自动提交表单,首先在页面加载完成后注册change事件,然后检测到值得变化后提交上传代码,代码备忘. <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <script> window.

21、在选择的时候跳到另一页面上,选择男女,然后提交表单内容

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> <script type="text/javascript"> function check() { var tr = document.createElement("tr"); var nam

删除DriverStore\FileRepository文件夹后,设备驱动无法安装,提示“没有为设备信息集或元素选择驱动程序(代码 28)”的解决办法

前言: 我前几天手贱,整个FileRepository删除掉了,之后重启就出现了让人蛋疼的这个问题,因为出于各种原因不想重装系统,百度轮番换搜索词无果,虽然驱动装上了但新设备依然无法自动安装驱动等"一堆瑕疵",重启无数次折腾3天之后才在百度一个帖子的一个字眼里发现了解决办法(说此方法的人自己说删了INFCACHE.1后也无效,所以没有引起注意),也因此有了这个随笔: 1.首先你要恢复FileRepository文件夹,至于方法嘛,可以下载完整的WIN7系统镜像后提取出来,如果是原版则用

jQuery 关于IE9上传文件无法进入后台原因及解决办法(ajaxfileupload.js第四弹)

第四弹的诞生完全不在自己最初的计划之中,是有个网友看了先前关于<ajaxfileupload.js系列>的文章后提出的问题,由于自己一直是用chrome浏览器去测试demo,完全忽略IE浏览器(其实是故意的,懒得想浏览器兼容的问题,哈哈~),所以当我使用IE9去运行demo的时候,确实发现了同样的问题,就是ajax异步提交表单无法进入后台. 下面是解决整个问题的过程,以我在<jQuery 自制上传头像插件-附带Demo实例(ajaxfileupload.js第三弹) >中上传的de

第一百八十六节,jQuery,验证表单插件,Ajax 表单插件,验证和提交表单

jQuery,验证表单插件,Ajax 表单插件,验证和提交表单 HTML <form id="reg" method="post" action="yzh.php" title="会员注册"> <ol class="reg_error"></ol> <p> <label for="user">帐号:</label>

android 读取DDMS里的文件时打不开,解决办法

1.问题:安卓自带数据库SQLite数据读取时(ddms---data----data----yourprojectname----databases),当点击data时目录展不开.从而无法查看数据库表中的数据. 2.方法:第一获得ROOT权限,如何获得root权限?我下载了一个一键root工具,挺好用的 (muzisoft.exe)安装在电脑上,并连接手机.点击一键root,等几分钟即可. 3.修改要查看文件的权限,下载一个RE(R.E管理器)并安装在手机上,运行,长按要查看的文件,在弹出的列

ajax提交表单、ajax实现文件上传

ajax提交表单.ajax实现文件上传,有需要的朋友可以参考下. 方式一:利用from表单的targer属性 + 隐藏的iframe 达到类似效果, 支持提交含有文件和普通数据的复杂表单 方式二:使用jquery的$.ajax({..}), 支持提交普通表单,但不支持含有文件的复杂表单; ($.post 或 $.get底层用的都是$.ajax) 方式三:使用jquery插件ajaxFileUpload.js, 支持上传文件,但不支持提交表单 方式四:使用jquery.from.js,支持提交同时

php实现点击文字提交表单并传递数据至下一个页面

<?php $id="4";//等会要把这个数据传到第二个页面 ?> <?php echo "<li>"; echo "<form name=\"myquestion\" method=\"post\" action=\"question.php\">"; echo "<input name=\"questionID\&