博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
kindeditor 上传文件控件优化下。。
阅读量:5886 次
发布时间:2019-06-19

本文共 4366 字,大约阅读时间需要 14 分钟。

hot3.png

默认情况下,文件上传完成后,文件说明处为空值。但是但多的状况这边是需要显示文件的名称。所所以就在数据回填的时候把文件的名称返回了。效果如图:

要实现这个效果,需要修改两个文件。

1.upload_json.jsp

 

JSONObject obj = new JSONObject();

 obj.put("error", 0);
 obj.put("url", saveUrl + newFileName);
 obj.put("title", fileName);
 System.out.println(fileName);
 out.println(obj.toJSONString());

2./kindeditor-4.1.7/plugins/insertfile/insertfile.js 文件,修改为如下

/*******************************************************************************

* KindEditor - WYSIWYG HTML Editor for Internet
* Copyright (C) 2006-2011 kindsoft.net
*
* Roddy < >
*
* @licence
*******************************************************************************/

KindEditor.plugin('insertfile', function(K) {

 var self = this, name = 'insertfile',
  allowFileUpload = K.undef(self.allowFileUpload, true),
  allowFileManager = K.undef(self.allowFileManager, false),
  formatUploadUrl = K.undef(self.formatUploadUrl, true),
  uploadJson = K.undef(self.uploadJson, self.basePath + 'php/upload_json.php'),
  extraParams = K.undef(self.extraFileUploadParams, {}),
  filePostName = K.undef(self.filePostName, 'imgFile'),
  lang = self.lang(name + '.');
 self.plugin.fileDialog = function(options) {
  var fileUrl = K.undef(options.fileUrl, 'http://'),
   fileTitle = K.undef(options.fileTitle, ''),
   clickFn = options.clickFn;
  var html = [
   '<div style="padding:20px;">',
   '<div class="ke-dialog-row">',
   '<label for="keUrl" style="width:60px;">' + lang.url + '</label>',
   '<input type="text" id="keUrl" name="url" class="ke-input-text" style="width:160px;" /> &nbsp;',
   '<input type="button" class="ke-upload-button" value="' + lang.upload + '" /> &nbsp;',
   '<span class="ke-button-common ke-button-outer">',
   '<input type="button" class="ke-button-common ke-button" name="viewServer" value="' + lang.viewServer + '" />',
   '</span>',
   '</div>',
   //title
   '<div class="ke-dialog-row">',
   '<label for="keTitle" style="width:60px;">' + lang.title + '</label>',
   '<input type="text" id="keTitle" class="ke-input-text" name="title" value="" style="width:160px;" /></div>',
   '</div>',
   //form end
   '</form>',
   '</div>'
   ].join('');
  var dialog = self.createDialog({
   name : name,
   width : 450,
   title : self.lang(name),
   body : html,
   yesBtn : {
    name : self.lang('yes'),
    click : function(e) {
     var url = K.trim(urlBox.val()),
      title = titleBox.val();
    var str="<img width='15px' src='http://demo.sc.chinaz.com/Files/pic/iconsico/dn_wj_65/blue%20folder%20+%20doc.ico' alt='"+title+"'/>";
     title=str+"&nbsp;&nbsp;"+title;
     if (url == 'http://' || K.invalidUrl(url)) {
      alert(self.lang('invalidUrl'));
      urlBox[0].focus();
      return;
     }
     if (K.trim(title) === '') {
      title = url;
     }
     clickFn.call(self, url, title);
    }
   }
  }),
  div = dialog.div;

  var urlBox = K('[name="url"]', div),

   viewServerBtn = K('[name="viewServer"]', div),
   titleBox = K('[name="title"]', div);

  if (allowFileUpload) {

   var uploadbutton = K.uploadbutton({
    button : K('.ke-upload-button', div)[0],
    fieldName : filePostName,
    url : K.addParam(uploadJson, 'dir=file'),
    extraParams : extraParams,
    afterUpload : function(data) {
     dialog.hideLoading();
     if (data.error === 0) {
      var url = data.url;
      var title = data.title;
      
      if (formatUploadUrl) {
       url = K.formatUrl(url, 'absolute');
      }
      urlBox.val(url);
      titleBox.val(title);
      if (self.afterUpload) {
       self.afterUpload.call(self, url, data, name);
      }
      alert(self.lang('uploadSuccess'));
     } else {
      alert(data.message);
     }
    },
    afterError : function(html) {
     dialog.hideLoading();
     self.errorDialog(html);
    }
   });
   uploadbutton.fileBox.change(function(e) {
    dialog.showLoading(self.lang('uploadLoading'));
    uploadbutton.submit();
   });
  } else {
   K('.ke-upload-button', div).hide();
  }
  if (allowFileManager) {
   viewServerBtn.click(function(e) {
    self.loadPlugin('filemanager', function() {
     self.plugin.filemanagerDialog({
      viewType : 'LIST',
      dirName : 'file',
      clickFn : function(url, title) {
       if (self.dialogs.length > 1) {
        K('[name="url"]', div).val(url);
        if (self.afterSelectFile) {
         self.afterSelectFile.call(self, url);
        }
        self.hideDialog();
       }
      }
     });
    });
   });
  } else {
   viewServerBtn.hide();
  }
  
  urlBox.val(fileUrl);
  titleBox.val(fileTitle);
  urlBox[0].focus();
  urlBox[0].select();
 };
 self.clickToolbar(name, function() {
  self.plugin.fileDialog({
   clickFn : function(url, title) {
    
    var html = '<a class="ke-insertfile" href="' + url + '" data-ke-src="' + url + '" target="_blank">' + title + '</a>';
    self.insertHtml(html).hideDialog().focus();
   }
  });
 });
});

 

转载于:https://my.oschina.net/zixiao/blog/148500

你可能感兴趣的文章
面试题28:字符串的排列
查看>>
css important
查看>>
WPF 实现窗体拖动
查看>>
NULL不是数值
查看>>
Oracle学习笔记之五,Oracle 11g的PL/SQL入门
查看>>
css绘制几何图形
查看>>
结合kmp算法的匹配动画浅析其基本思想
查看>>
Android网络编程11之源码解析Retrofit
查看>>
安全预警:全球13.5亿的ARRIS有线调制解调器可被远程攻击
查看>>
麦子学院与阿里云战略合作 在线教育领军者技术实力被认可
查看>>
正确看待大数据
查看>>
Facebook通过10亿单词构建有效的神经网络语言模型
查看>>
发展大数据不能抛弃“小数据”
查看>>
中了WannaCry病毒的电脑几乎都是Win 7
查看>>
学生机房虚拟化(九)系统操作设计思路
查看>>
nginx报错pread() returned only 0 bytes instead of 4091的分析
查看>>
质数因子
查看>>
Spring源码浅析之事务(四)
查看>>
[转载] Live Writer 配置写 CSDN、BlogBus、cnBlogs、163、sina 博客
查看>>
SQL:连表查询
查看>>