TinyMCE这个东西很多地方再用,不过我以前一直没用过,最近才接触,因为有一套现成的metro风格的皮肤,仅此而已,不过最终如何调用还是我得来实现。其他的都好说,网上的资料一大把一大把的,唯独这个本地图片上传,网上查的资料都是三言两语,不成体系,有些地方总归是没有说到,费了好大劲儿,总算是闹明白怎么弄这个了。(大牛们这次怎么就不能一起愉快的玩耍呢……)

TinyMCE中使用本地上传图片,实际上是在TinyMCE中使用了一个编写好的插件。这个插件自定义性非常大,按照你的想法,想干嘛就干嘛。

首先一点,在TinyMCE编辑器初始化时启用图片功能,这个不说了,网上资料都有,一大把一大把的。这里只举一个例子:

tinymce.init({
selector: 'textarea',
mode: "textareas",
theme: "advanced",
plugins: "preview",
theme_advanced_toolbar_location: "top",
theme_advanced_toolbar_align: "left",
theme_advanced_buttons1: "bold, italic, underline, strikethrough, justifyleft, justifycenter, justifyright, justifyfull, bullist, numlist, outdent, indent, undo,redo, link, unlink, hr, formatselect, fontselect, fontsizeselect, forecolor,spacer,cut,copy,paste, image,cleanup, code, myplugins,preview",
theme_advanced_buttons2: "",
theme_advanced_buttons3: "",
});
tinymce.mceImage

然后直奔本地图片上传。

核心要关注的就是这个htm页面和image.js文件这两个。

image.htm这个里面你可以完全自己定义,不用太操心,你希望他是什么样子都可以,一般都会跟你整体项目的UI框架保持一致,当然也有特别炫酷的。当你觉得他的墨阳能够让你满意,记得在head标签区域内引用“image.js”文件。这个很重要。

这里我们还用到了jquery.form.js这个经典的插件,主要是要用它来实现ajax提交表单。

这里是我自己的代码,给大家参考下:

<head>
<script src="../../../../../Scripts/jquery-1.7.1.min.js"></script>
<script type="text/javascript" src="../../../jquery.form.js"></script>
<script type="text/javascript" src="../../tiny_mce_popup.js"></script>
<script type="text/javascript" src="../../utils/mctabs.js"></script>
<script type="text/javascript" src="../../utils/form_utils.js"></script>
<script type="text/javascript" src="js/image.js"></script>
</head>

上面的东西除了jquery.form.js都可以在插件内部找到,这里不再一一解释作用了。往下就是html主体部分,这个大家随意,反正只要有个form标签,里面再有个<input type='file' ……>就可以了。

先说上传本身,上传本身要利用ajax提交表单,具体来说就是利用jquery.form.js中的ajaxSubmit方法,参数和Jquery的ajax一样,但是不需要传递data参数,因为表单本身在内部会处理完当做post方式传输。与此同时,对于上传文件来说,form表单中需要设置如下内容:

method="post" enctype="multipart/form-data" action="……"

method和action两个属性不解释了,如有疑问请自行百度。enctype 属性规定在发送到服务器之前应该如何对表单数据进行编码,默认值是“application/x-www-form-urlencoded”,编码所有字符,“text/plain”是指不编码特殊字符,但会将空格转换为 "+" 加号,还有一个值就是我们用到的“multipart/form-data”,该值为不对字符编码,上传文件的请求必须使用这个值。这种方式的核心在于post请求的数据在文件数据和文本数据中存在分隔符,具体的不赘述太多了。

然后是表单 提交的部分(重头戏哦):

if (document.getElementById("upload").value == "") {
alert("请选择一个图片文件,再点击上传。");
return;
}
$("#myForm").ajaxSubmit({
type: "POST", dataType: "text", url: "……", async: true, success: function (value) {
if (value != "0") {
$("#src").val(value);
$("#uploadsrc").html("<img src='"+value+"' />");
}
else {
alert("上传失败");
}
}, error: function (value) {
alert("失败" + value);
}
});

方法里看到对于表单“myForm”使用了ajaxSubmit方法,方法跟jquery本身的ajax一样,简单明了,至于后台的代码这里不说了,如果有同学需要的话可以百度,或者联系我。在文件上传完毕之后,可以看到在例子中我是把图片显示了出来,这样主要为了方便,预览一下再确定,省的误操作,这个大家可以根据自己的用户习惯和要求来设计。

然后就是如何把图片添加到文本编辑器里了。因为TinyMCE的方式是弹出窗口,注意是窗口,不是层。对于这样的弹出窗口,一般情况下我们会有插入,取消之类的按钮来使用,这里只说插入和取消,其他的就不说了。

取消:主要功能为删除图片,关闭窗口,删除图片这个在自己后台处理就是了,用一个ajax方法,后台删除就是了,服务端代码这里不做研究了。关闭窗口我们使用TinyMCE的方法:tinyMCEPopup.close(),这样可以直接关闭弹出窗口并使焦点回到富文本编辑器本身。

插入:把刚刚上传的图片对象插入到富文本编辑器当前的光标所在处。并关闭弹出窗口,这里就要用到前文提到的image.js了。这个image.js文件,tinyMCE本身就有,但是不见得适用每个人,所以需要自行修改。

文件中有一个声明好的全局变量:ImageDialog,这里面可以做很多东西。文件本身有很多方法,大家感兴趣的可以研究下,这里只说一些我们马上就需要用到的代码。

insertAndClose: function () {
var ed = tinyMCEPopup.editor, f = document.forms[0], nl = f.elements, v, args = {}, el; tinyMCEPopup.restoreSelection(); // Fixes crash in Safari
if (tinymce.isWebKit)
ed.getWin().focus(); if (!ed.settings.inline_styles) {
args = {
vspace: nl.vspace.value,
hspace: nl.hspace.value,
border: nl.border.value,
align: getSelectValue(f, 'align')
};
} else {
// Remove deprecated values
args = {
vspace: '',
hspace: '',
border: '',
align: ''
};
} tinymce.extend(args, {
src: nl.src.value.replace(/ /g, '%20'),
width: 100,
height: 100,
alt: "",
title: "",
'class': getSelectValue(f, 'class_list'),
style: "",
id: "",
dir: "",
lang: "",
usemap: "",
longdesc: ""
}); args.onmouseover = args.onmouseout = ''; //if (f.onmousemovecheck.checked) {
// if (nl.onmouseoversrc.value)
// args.onmouseover = "this.src='" + nl.onmouseoversrc.value + "';"; // if (nl.onmouseoutsrc.value)
// args.onmouseout = "this.src='" + nl.onmouseoutsrc.value + "';";
//} el = ed.selection.getNode(); if (el && el.nodeName == 'IMG') {
ed.dom.setAttribs(el, args);
} else {
tinymce.each(args, function (value, name) {
if (value === "") {
delete args[name];
}
}); ed.execCommand('mceInsertContent', false, tinyMCEPopup.editor.dom.createHTML('img', args), { skip_undo: 1 });
ed.undoManager.add();
} tinyMCEPopup.editor.execCommand('mceRepaint');
tinyMCEPopup.editor.focus();
tinyMCEPopup.close();
}

这个方法是我根绝别人的东西改改直接用的,方法是把图片添加到富文本编辑器当前光标处并关闭弹出窗口的。其中:

tinyMCEPopup是tinyMCE的弹出窗口对象,利用他可以通过tinyMCEPopup.editor操作富文本编辑器,同时,tinymce是tinymce的全局对象。

在方法中:

tinymce.extend(args, {

   src: nl.src.value.replace(/ /g, '%20'),

   width: 100,

   height: 100,

   alt: "",

   title: "",

   'class': getSelectValue(f, 'class_list'),

   style: "",

   id: "",

   dir: "",

   lang: "",

   usemap: "",

   longdesc: ""

});

这个方法我是自己改的很死,因为我的需求没有那么严格,所以这些参数我都是写死的,各位根据需要自行修改吧,这是初始化的设定。

编写完成关闭方法,还需要调用,在HTML页面中,在插入按钮对应的点击方法中,可以直接使用:ImageDialog.insertAndClose()方式调用。

以上,就是基本的tinyMCE本地图片上传功能,往下就是根据需要调整了,各位发挥才智,可以各种酷炫哦。

TinyMCE实现简单的本地上传的更多相关文章

  1. ASP.NET MVC4实现TinyMCE 4.0.20自定义上传功能

    tinymce 插件不提供免费的本地图片上传功能,所以自己将uploadify这个上传插件整合到tinymce,实现本地上传,还用到了jquery.ui插件,先展示全部的代码 @model TinyM ...

  2. window系统下,简单的FTP上传和下载操作

    先假设有一FTP服务器,FTP服务器:qint.ithot.net,用户名:username   密码:user1234.在本地电脑D:盘创建一个文件夹"qint".将要上传的文件 ...

  3. 使用jsp/servlet简单实现文件上传与下载

    使用JSP/Servlet简单实现文件上传与下载    通过学习黑马jsp教学视频,我学会了使用jsp与servlet简单地实现web的文件的上传与下载,首先感谢黑马.好了,下面来简单了解如何通过使用 ...

  4. 简单的GIT上传

    简单的GIT上传 上传项目时先新建一个 文件夹 mkdir test 然后在切换到test文件夹中然后把github 中的项目拷贝下来 git glone url 然后git init 查看文件 然后 ...

  5. Django 实现简单的文件上传

    今天分享一下Django实现的简单的文件上传的小例子. 步骤 创建Django项目,创建Django应用 设计模型 处理urls.py 以及views.py 设计模板,设计表单 运行项目,查看数据库 ...

  6. UEditor之实现配置简单的图片上传示例

    UEditor之实现配置简单的图片上传示例 原创 2016年06月11日 18:27:31 开心一笑 下班后,阿华到楼下小超市买毛巾,刚买完出来,就遇到同一办公楼里另一家公司的阿菲,之前与她远远的有过 ...

  7. maven本地上传jar包

    maven本地上传jar包 在命令行中输入下面指令(是一行): mvn install:install-file -Dfile=D:\mvn\spring-context-support-3.1.0. ...

  8. Django中从本地上传excel文件并将数据存储到数据库

    Django中从本地上传excel文件并将数据存储到数据库 一.前端界面 <div class="page-container"> <form action=&q ...

  9. 服务器文档下载zip格式 SQL Server SQL分页查询 C#过滤html标签 EF 延时加载与死锁 在JS方法中返回多个值的三种方法(转载) IEnumerable,ICollection,IList接口问题 不吹不擂,你想要的Python面试都在这里了【315+道题】 基于mvc三层架构和ajax技术实现最简单的文件上传 事件管理

    服务器文档下载zip格式   刚好这次项目中遇到了这个东西,就来弄一下,挺简单的,但是前台调用的时候弄错了,浪费了大半天的时间,本人也是菜鸟一枚.开始吧.(MVC的) @using Rattan.Co ...

随机推荐

  1. Android开发调节屏幕亮度

    在播放器,我们经常看到这样的设计,即,在用户的特定部分将能够滑动屏幕向上或向下调整屏幕的亮度,上下滑动的某一部分将能够调整播放音量.并以滑动的进程可以进行调整,以玩. 如今,我不得不说一下亮度调节. ...

  2. 发现C++Builder 2010一组类BUG

        今天C++Builder 2010写小码,我们用一个集合类.您可以设置操作结果是不正确的,排除其他原因引起的,最后,它应该被设置以确定问题类的源,以下是一个集合类测试代码: enum TTes ...

  3. java Socket使用详细解释

    客户/server通信模式, client需要主动创造和server Socket(套接字), server端收到了client的连接请求, 也会创建与客户连接的 Socket. Socket可看做是 ...

  4. 配置jndi服务,javax.naming.NamingException的四种情况

    1.当jndi服务没有启动,或者jndi服务的属性没有设置正确,抛出如下异常: javax.naming.CommunicationException: Can't find SerialContex ...

  5. 【原创】java中的父进程子进程 —— 坑爹的java Runtime.getRuntime().exec

    最近有一个需求,需要用一个java进程启动多个子进程来完成并发任务.由于必须给用户完成任务的反馈,所以需要父进程记录子进程的生命周期. exec方法返回一个Process对象,在当前进程内调用该对象的 ...

  6. Easyui 异步树直接所有展开

    初始化异步树直接所有展开代码: $(function(){ $('#tt').tree({ url:'<%=request.getContextPath()%>/treeInit', li ...

  7. Sqlserver中Over函数

    Over函数不能单独使用,要和分析函数:rank(),dense_rank(),row_number()等一起使用.  其参数:over(partition by columnname1 order ...

  8. Leetcode:minimum_depth_of_binary_tree解决问题的方法

    一.     称号 并寻求最深的二元相似.给定的二进制树.求其最小深度. 最小深度是沿从根节点,到叶节点最短的路径. 二.     分析 当我看到这个题目时.我直接将最深二叉树的代码略微改了下,把ma ...

  9. S如何解决安卓DK无法下载Package问题

    安装一些用户Android SDK后.打开Android SDK Manager下载API当总是显示"Done loading packages"却迟迟不能前进.自己也出现了这样的 ...

  10. [LeetCode228]Summary Ranges

    题目: Given a sorted integer array without duplicates, return the summary of its ranges. For example, ...