之前在时候用到webuploader ,起初是支持单实例,后来要求支持多实例.

webuploder API网址,如果不懂我说的可以去查看http://fex.baidu.com/webuploader/doc/index.html#WebUploader_Uploader_addButton

addButton

  • addButton( pick ) ⇒ Promise

添加文件选择按钮,如果一个按钮不够,需要调用此方法来添加。参数跟options.pick一致。

  1. uploader.addButton({
  2. id: '#btnContainer',
  3. innerHTML: '选择文件'
  4. });

下面是个人实例:

1.首先是页面

 

< = = =>
< =

  • =
  • = = = = =  =>
    >
    >
     = =></>
     =>
     = =>
     =>
    > = = > > = =
  • = =   = = = =   = =
  • = =
  • >
    >
    >
    >
     = =></>
    > == = =>>>
    >
    >
    >>
    >
     =
  • =>
     =>< =>>
    >
    >
     =>
     = =
  • = = = =
  • = =>
     = ==></>
  • ==>>
     = = =>
    >
    >
  • >
    >
    >
    >
    >
    >
    >>
    > = = = ="evalution({{=ord.odetId}},{{=ord.prod_id}})"="per_evaluate_btn upload_btn" = >
    >
    >
    >
    >
    </>
    </>

我们用的模板是doT.js来遍历集合  当然也有很多其他方式 比如说最近见到 用easyui框架 也可以显示列表

2. JavaScript

 

var;

  • evacom = 1;
  • fileNumLimit = 10000;
  • multiple = ;
  • imgtype = ;
  • punit = ;
  • (oldImgUrl != ) {
  • getImgByJson(oldImgUrl);
  • () {
  • FormValidation.init();
  • bigImg(id) {
  • deal(id) {
  • evacom = id;
  • + evacom);
  • }
  • amy_evaluate() {
  • $().css(, );
  • evaluate_off() {
  • ).css(, );
  • //
     showOrNo(ids) {
  • Imgmap =  Map();
  • + ids).raty({
  • width : 300
  • itid =  + ids;
  • (i, item) {
  • (ids != item.id) {
  • ,
  • multiple :
  • Map();
  • + evacom, Imgmap);
  • $list = $( + evacom);
  • (Imgmothermap == ) {
  • evacom = ids;
  • ,
  • multiple :
  • bloc =  + ids;
  • $(bloc).toggle();
  • }

3. Upload上传 Java关键代码

 

@RequestMapping, method = RequestMethod.POST)

  • getImgurlbyfile(HttpServletResponse response,
  • maxSize = ;
  • JSONObject();
  • String imgtype = request.getParameter();
  • );
  • ;
  • (Tools.isEmpty(imgtype)) {
  • , );
  • json.put(,
  • ));
  • }  {
  • (getBoolByType(myfile.getOriginalFilename().toLowerCase())) {
  • (myfile.getSize() <= maxSize) {
  • ( != myfile && !myfile.isEmpty()) {
  • (imgtype) {
  • :
  • filePath = Tools.uploadpicByShow(myfile, imgtype,
  • , , , , );
  • json.put(, );
  • , );
  • json.put(, filePath);
  • ;
  • :
  • );
  • , );
  • json.put(, );
  • , filePath);
  • ;
  • :
  • filePath = Tools.uploadpic(myfile, imgtype);
  • , );
  • json.put(, );
  • , filePath);
  • ;
  • {
  • , );
  • json.put(, BaseConfig.MESSAGE
  • ));
  • }
  • {
  • json.put(, );
  • ,
  • BaseConfig.MESSAGE.get());
  • {
  • , );
  • json.put(,
  • ));
  • }
  • {
  • (UnsupportedEncodingException e) {
  • e.printStackTrace();
  • }

webupload.js

 

$list = $();

  • count=0;
  • var Map();
  • thumbnailWidth = 100;
  • var
  • ,
  • fileVal : ,
  • ,
  • duplicate : ,
  • server : SHOPDOMAIN+ ,
  • ,
  • ,
  • ,
  • mimeTypes :
  • });
  • // 当有文件添加进来的时候
    'fileQueued'function
     $li = $(
  • + ), $img = $li
  • );
  • $btns = $(
  • , () {

  • $( + file.id).stop()
  • //      .animate({
    //          height : 30
    //      });

    , () {

  • + file.id).stop()
  • //          height : 0
    //      });

    , , () {

  • index = $().index(), deg;
  • (index) {
  • 0:
  • ;
  • 1:
  • $nextId=$(+file.id).next();
  • (undefined!=$nextId.attr()){
  • tempSrc=Imgmap.get($nextId.attr());
  • tempWu_File=$(+file.id);
  • Imgmap.put($nextId.attr(), Imgmap.get(file.id));
  • + file.id).stop().animate({
  • height : 0
  • ).html(Imgmap.toString());
  • ;
  • 2:
  • $prevId=$(+file.id).prev();
  • (undefined!=$prevId.attr()){
  • tempSrc=Imgmap.get($prevId.attr());
  • tempWu_File=$(+file.id);
  • ), Imgmap.get(file.id));
  • Imgmap.put(file.id, tempSrc);
  • + file.id).stop().animate({
  • ).html(Imgmap.toString());
  • }
  • ;
  • }
  • $list.append($li);
  • (error, src) {
  • (error) {
  • );
  • ;
  • , src);
  • }, thumbnailWidth, thumbnailHeight);
  • // 文件上传过程中创建进度条实时显示。
    'uploadProgress'(file, percentage) {
  • $li = $( + file.id), $percent = $li.find();
  • (!$percent.length) {
  • $percent = $(
    );
  • }
  • , percentage * 100 + );
  • // 文件上传成功,给item添加成功class, 用样式标记上传成功。
    'uploadSuccess'(file, response) {
  • ).css(,);
  • ).html(Imgmap.toString());
  • $( + file.id).addClass();
  • // 文件上传失败,显示上传出错。
    'uploadError'(file) {
  • $li = $( + file.id), $error = $li.find();
  • (!$error.length) {
  • $error = $(

    );

  • // 完成上传完了,成功或者失败,先删除进度条。
    'uploadComplete'(file) {
  • + file.id).find().remove();
  • });
  • // 完成上传完了,成功或者失败,先删除进度条。
    'error'(file) {
  • showMessage(file);
  • function
     tempImgPath = $().html();
  • (Imgmap.size()==0){
  • ).css(,);
  • }
  • ).html(Imgmap.toString());
  • $( + fileId).remove();
  • function

    ).css(,);

  • ( i=0; i<json.length; i++)
  • +json[i].id, json[i].uri);
  • $li = $(
    '_160''">'

    + ), $img = $li

  • );
  • $btns = $(
  • '">'

    , () {

  • tempId=$().attr();
  • $( + tempId).stop().animate({
  • , () {
  • tempId=$().attr();
  • + tempId).stop().animate({
  • height : 0
  • , , () {
  • tempId=$().parent().attr();
  • index = $().index(), deg;
  • (index) {
  • 0:
  • +tempId);
  • ;
  • 1:
  • $nextId=$(+tempId).next();
  • (undefined!=$nextId.attr()){
  • tempSrc=Imgmap.get($nextId.attr());
  • tempWu_File=$(+tempId);
  • Imgmap.put($nextId.attr(), Imgmap.get(+tempId));
  • +tempId, tempSrc);
  • $nextId.after(tempWu_File);
  • +tempId).stop().animate({
  • height : 0
  • ).html(Imgmap.toString());
  • ;
  • 2:
  • $prevId=$(+tempId).prev();
  • (undefined!=$prevId.attr()){
  • tempSrc=Imgmap.get($prevId.attr());
  • tempWu_File=$(+tempId);
  • ), Imgmap.get(+tempId));
  • Imgmap.put(+tempId, tempSrc);
  • +tempId).stop().animate({
  • ).html(Imgmap.toString());
  • }
  • ;
  • }
  • $list.append($li);
  • ).html(Imgmap.toString());
  • }

原理, 就是每次点击按钮的时候 对按钮进行绑定事件

 

addButton

  • addButton( pick ) ⇒ Promise
  • ,
  • });

每个按钮都有不同的id,所以说webuploader可以实例化多个按钮,这是重点,这样一个页面就支持多个评论了。

webuploader在同一个页面支持多个按钮实例的更多相关文章

  1. webuploader的一个页面多个上传按钮实例

    借鉴一位大佬的demo  附上他的github地址https://github.com/lishuqi 我把他的cxuploader.js改了不需要预览  直接上传图片后拿到回传地址给img标签显示图 ...

  2. [转] c# 模拟Asp.net页面中的某个按钮的点击,向web服务器发出请求

    在没有做题目中所述的内容的时候,感觉这应该是很简单的东西,但是当真正开始做的时候却发现,有很多问题现在在这里写出来,供和我一样水平不高的参考一下. 在写本文之前参照了一下文章 欢迎使用CSDN论坛阅读 ...

  3. 完美实现在同一个页面中使用不同样式的artDialog样式

    偶然发现artDialog.js这个插件,就被其优雅的设计及漂亮的效果深深吸引,在做例子时碰到了一些想当然它应该提供但却没有提供的功能,不过这都不影响我对它的喜爱,下面说一下遇到的问题吧! artDi ...

  4. iOS 实现单个页面支持横竖屏,其他页面只能竖屏

    最近在自己的项目里面 有需要做一个需求 : app中某一个页面支持横竖屏, 而其他页面只能竖屏. 1 2 实现方法如下: 1 首先需要Xcode中选中支持的屏幕方向  2 Appdelegate中 . ...

  5. 小程序webview跳转页面后没有返回按钮完美解决方案

    随着小程序越来越火爆,使一个产品如果只有公众号H5页面和APP显得不怎么完美,总感觉不搭上小程序这趟流量车,就会少了点什么,心里别扭地很.在此驱动下,我所在公司也决定赶紧上车. 但是,如果要按照小程序 ...

  6. 在同一个页面使用多个不同的jQuery版本,让它们并存而不冲突

    - jQuery自诞生以来,版本越来越多,而且jQuery官网的新版本还在不断的更新和发布中,现已经达到了1.6.4版本,但是我们在以前的项目中就已经使用了旧版本的jQuery,比如已经出现的:1.3 ...

  7. asp.net mvc jqgrid 同一个页面查询不同的表,jqgrid显示不同表的表头和数据并且分页

    基于我上一篇文章<a href="http://www.cnblogs.com/alasai/p/4765756.html">asp.net mvc excel导入&l ...

  8. 自己改写了一个图片局部放大的jquery插件页面里面的html代码少了,同一个页面可以调用多个

    自己改写了一个图片局部放大的jquery插件页面里面的html代码少了,同一个页面可以调用多个,兼容ie8以上浏览器,别忘了引用jquery,我用的jquery/1.11.0/其他版本没有测试,另外需 ...

  9. 多个测试类 只使用同一个浏览器,同一个driver对象, 或者同一个页面的对象

    如果是:多个测试类 只使用同一个浏览器,同一个driver对象, 或者同一个页面的对象,只需要:1. 创建一个基本的测试类(BaseTest),具有一个公共静态的driver属性, public st ...

随机推荐

  1. myeclipse10安装egit和使用

    一.下载egit插件并安装到eclipse 下载egit插件包,然后解压放到Eclipse的dropins文件夹内或者直接放到对应的文件夹下 二.安装成功(window->preferences ...

  2. javascript闭包,arguments和prototype

    prototype javascript中一切皆对象,并且对象的属性和方法可以任意添加,例如: var obj=function(){}; obj.name="jack"; 但是下 ...

  3. vb6 判断64位操作系统

    Option Explicit Private Declare Function GetCurrentProcess Lib "kernel32" () As Long Priva ...

  4. 如何使用投影看着备注分享自己的PPT

    1.  设置多屏幕 一般你的笔记本就是1,   投影是2 2. 设置幻灯片的放映方式 设置幻灯片显示于另外一个监视器  并勾选显示演示者视图 3.  点击放映 就会出现 左上角是ppt本身, 右上角是 ...

  5. WordPress中"无法将上传的文件移动至"错误的解决方法

    #chown -R www:www /wwwroot 今天在网页上传图片到博客,结果提示:“无法将上传的文件移动至 /home/wwwroot/wp-content/uploads/2013/”,郁闷 ...

  6. css禁用鼠标点击事件

    css禁用鼠标点击事件 .disabled { pointer-events: none; } <div class="main-container disabled"> ...

  7. sphinx 配置sphinx.conf

    sphinx的配置文件是在配置的时候最容易出错的了: 基本概念: source:数据源,数据是从什么地方来的. index:索引,当有数据源之后,从数据源处构建索引.索引实际上就是相当于一个字典检索. ...

  8. JavaScript中的继承模式总结

    一.总结: //js中的几种继承 //原型链的问题,包含引用类型的原型属性会被实例共享,子类型无法给超类型传递参数 function SuperType() { this.colors = [&quo ...

  9. hyper-v 中 安装 Centos 7.0 设置网络 教程

    安装环境是: 系统:win server 2012 r2 DataCenter hyper-v版本:6.3.9600.16384 centos版本:7.0 从网上下载的 centos 7.0  如果找 ...

  10. 关于今天mysql数据库的一系列问题

    首先,字符集的问题: mysql> show variables like 'character%';+--------------------------+------------------ ...