示例:使用quill富文本编辑器的插件,自定义formData图片上传
>[info]官网地址:[https://quilljs.com](https://quilljs.com/)
项目需求:自带的上传图片是base64,直接入库的话,请求头太长,导致网页十分十分的卡,所以才改用formData自定义上传(改完之后,相当于覆盖了他本身自带的上传按钮,图标是一样的,就是说在外观上看不出来变化)
[toc]
## :-: **效果图**
- 刚引入好,的效果图
![](https://box.kancloud.cn/c9691e5aeddff647c6b92be5f048daf4_1247x253.png)
- 当文本框中没有任何内容的时候,`quill.container.firstChild.innerHTML`默认为 `<p><br></p>`
![](https://box.kancloud.cn/93a74082f9cde00fe76c9274159060c3_1202x425.png)
- 上传图片后,的效果
代码是没问题的,因为我这是本地测试,图片只能传到固定的某个盘了,懒的改了...
![](https://box.kancloud.cn/14a0f42a87cdb692115e071bef6723bb_1266x512.png)
- 上传视频后,的效果
![](https://box.kancloud.cn/7e611bc340bfbd84e82b1cbd377a1620_1296x394.png)
## :-: **前端代码**
``` html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
<title>QuillDemo</title>
<link href="//cdn.quilljs.com/1.3.6/quill.snow.css" rel="stylesheet">
<link href="//cdn.quilljs.com/1.3.6/quill.bubble.css" rel="stylesheet">
<style>
body {
padding: 10px 30px;
}
#editor {
min-height: 180px;
}
</style>
</head>
<body>
<form method="POST" action="test.php">
<div>
<!--当toolbar以container的形式注册时需要显式地写出这些标签-->
<div id="editor_header" style="display: none;">
<!--字体大小-->
<select class="ql-size">
<option value="small"></option>
<!-- 默认按钮 -->
<option selected></option>
<option value="large"></option>
<option value="huge"></option>
</select>
<!--加粗按钮-->
<button class="ql-bold"></button>
<!--上标、下标按钮-->
<button class="ql-script" value="sub"></button>
<button class="ql-script" value="super"></button>
<!--自定义按钮-->
<button id="my_button"></button>
</div>
<div id="editor" class="showContent">
<!--回显的内容,库中查出来的放这-->
<!--可以直接在指定元素内加入文本或者html标签-->
哈哈哈哈
</div>
<input type="hidden" id="richText" name="richText" style="display: none;" value="" /> <!--用于form表单提交-->
</div>
<form enctype="multipart/form-data" id="imgFrom">
<!-- this.files[0] 图片列表的第0项,也就是当前选择的图片 -->
<input type="file" onchange="updateImg(this.files[0])" id="imgData" style="display: none;">
</form>
<br />
<input type="submit" value="提交" id="su" onclick="submitData()" /> <!--id用于form表单时,将富文本编辑器的值,赋给隐藏域-->
</form>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.js"></script>
<script src="//cdn.quilljs.com/1.3.6/quill.js"></script>
<script>
/* 编辑器操作条选项 */
var toolbarOptions = [
['bold', 'italic', 'underline', 'strike'], //开关按钮
['blockquote', 'code-block'],
[{'header': 1}, {'header': 2}], //自定义按钮值
[{'list': 'ordered'}, {'list': 'bullet'}],
[{'script': 'sub'}, {'script': 'super'}], // 上标/下标
[{'indent': '-1'}, {'indent': '+1'}], // 减少缩进/缩进
[{'direction': 'rtl'}], // 文本方向
[{'size': ['small', false, 'large', 'huge']}], // 自定义下拉
[{'header': [1, 2, 3, 4, 5, 6, false]}],
[{'color': []}, {'background': []}], //使用主题的默认下拉
[{'font': []}],
[{'align': []}],
['clean'], //移除格式化
['image'],
['video'],
['formula'] //需要加载cdnjs.cloudflare.com/ajax/libs/KaTeX/0.7.1/katex.min.js
];
/* 实例化编辑器 */
var quill = new Quill('#editor', {
/*debug: 'info',*/
modules: {
//formula: true, //公式;需要加载cdnjs.cloudflare.com/ajax/libs/KaTeX/0.7.1/katex.min.js
//syntax: true, //高亮;需要加载cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/highlight.min.js
/*toolbar: {
container:"#editor_header"
}*/ // 或者 toolbar :'#editor_header'
toolbar:toolbarOptions //指定编辑器操作条
},
theme: 'snow', //主题,有两种,snow和bubble
placeholder:'请输入',
readOnly: false
});
//修改样式
var Align = Quill.import('attributors/style/align');
Align.whitelist = ['right', 'center', 'justify'];
Quill.register(Align, true);
/* 传入布尔值,控制编辑器是否可用 */
quill.enable();
//quill.blur(); //失去焦点
//quill.focus(); //获得焦点
/* 事件的绑定;注意:text-change这个获取值放这的话是编辑器内容发生改变的时候才能获取到值,如果想每次提交都有值,要放到提交那 */
quill.on('text-change', function(delta, oldDelta, source) {
// console.log(delta); //当前输入的
// console.log(oldDelta); //上一次输入的
// console.log(source);
//res = quill.container.firstChild.innerHTML; //获取当前富文本编辑器实例的内容(带html标签)
//console.log(res);
});
/* 自定义按钮 */
var myBtn = document.querySelector("#my_button");
myBtn.addEventListener("click",function(){
//console.log('my-btn')
});
//【自定义上传图片1】通过addHander来监听image事件
let toolbar = quill.getModule('toolbar');
toolbar.addHandler('image', () => {
document.getElementById('imgData').click();
});
//【自定义上传图片2】发送ajax处理好图片
function updateImg(file){
var formData = new FormData();
formData.append('avatar', file); //追加的自定义节点,第一个参数:php用$_FILES接收时的key;第2个参数:当前图片
console.log(formData.get("avatar")); //打印当前图片的信息
$.ajax({ //发送ajax
url:'index.php', //url
type:'post', //以post发送
data:formData, //要发送的数据。后端接收$_POST['user']
dataType:'json', //返回的数据类型
cache:false,
traditional: true,
contentType: false,
processData: false,
success:function(res){
console.log(res);
//图片上传成功之后的回调
const range = quill.getSelection();
if (range) {
quill.insertEmbed(range.index, 'image',""+res); //将上传好的图片,插入到富文本的range.index(当前光标处)
}
}
});
};
//form表单的提交
function submitData(){
res = quill.container.firstChild.innerHTML; //获取当前富文本编辑器实例的内容(带html标签)
console.log(res); //获取当前富文本编辑器实例的内容(带html标签)
$("#richText").val(res);
};
</script>
</body>
</html>
```
## :-: **后端代码**
~~~ php
<?php
//header("content-type:text/html;charset=utf-8"); //设置编码
$filePath = 'e:/'.date("Y-m-d").'.png'; //上传到哪个位置
$uploadUrl = move_uploaded_file($_FILES['avatar']['tmp_name'],$filePath); //【关键在这,上传文件】
$addr = 'http://'.$filePath;
echo json_encode($addr);
?>
~~~
后端接收到的,整个富文本编辑器中的内容(带html标签的),直接入库即可
- 杂谈
- 开发 & 维护的工作流程
- 新手如何看php手册 和 框架手册
- 开发 & 维护的不同点
- 从0到1,搭建新项目的工作流程
- 从1到N,维护的工作流程
- 优化流程
- 生成错误日志和慢日志的方法
- 查错思路
- 怎么快速接手一个项目
- 前端常用知识点
- javascript
- 自己封装的函数
- 处理数字
- 功能代码
- 动态添加图片
- 判断是手机端还是pc端
- javascript:;是什么意思?怎么用呢
- html & h5
- a标签中target设置为blank和_blank有什么区别?
- 乱码
- 提交方式:button标签 和 input
- 块元素
- 内联元素
- h5特有属性
- h5的localStorage【增、删、改、查】
- jquery
- 常用方法
- 功能代码
- 动态删除图片
- 一个按钮,切换2种状态
- 换肤
- 深入理解(function(){... })();
- json & xml
- json
- 语法速记
- json对象取值
- 字符串、对象、数组的区别
- xml
- [CDATA[%s]]的作用是什么
- 转义字符
- CDATA 想被xml解析的文本数据
- CDATA 不想被xml解析的文本数据
- 微信小程序
- 其他
- websocket
- 跨域
- css
- 行内 & 内连 & 外连 写法
- 优先级
- 更加精准的匹配
- 使用百分比如何生效
- php在html、js、jq中的的原生写法
- *php在html中的语法
- php在js中的语法
- php在jq中的语法
- 正则表达式
- php常用基础知识(思想为主)
- php为什么是“边编译边运行”
- 冒号、endif、endwhile、endfor使用
- 递归思想(速记法)
- cookie和session的理解
- php常用内置(系统)函数
- 常量
- 字符串
- 数组
- 日期时间
- 文件 & 目录
- 数学
- 程序执行
- 判断
- 选项和信息(修改配置文件的)
- 错误处理 & 日志记录
- 编码格式
- session
- IP相关
- 类 & 对象
- 性能
- 其他函数
- 魔术方法
- $_SERVER
- 变量处理
- php自己封装的一些函数
- 导入、导出、生成文件
- 数组
- 数字
- 字符串
- 其他
- 获取linux硬件信息
- 常见插件/类库使用
- 前端-框架/插件
- bootstrap 学习笔记
- layer 学习笔记
- layDate 学习笔记
- 百度ueditor1.4.4.3富文本编辑器
- quill富文本编辑器
- 百度ECharts图形报表
- webuploader上传图片
- 后端类库
- workerman 聊天室
- QRCODE 二维码
- redis
- seaslog 日志
- phpspider 爬虫
- Mailer 发送邮件
- simple_html_dom
- phpstorm使用
- 快捷键
- 连接mysql数据库
- 断点 + debug调试
- 运行内存不够
- wamp环境
- yii、laravel、tp、开发自己的php框架
- 看框架源码的思路
- tp5框架的使用
- 1、助手函数原理解析
- 开发自己的php框架
- 常用的开发思路 和 小功能实现代码
- 爬虫思路
- 功能点思路
- tp5判断是不是异地登录(简单版)
- 微信开发,反向代理
- 微信开发,关闭当前页面
- 消息队列的实现
- 页面静态化
- session串号
- 站内信设计思路
- web在线管理器
- 语言相关(开发有关)
- 接收json(text/xml)格式数据
- 原生文件上传(状态码)
- openssl扩展
- 打印对象 和 遍历对象
- 使用OB缓存的几个原则
- CLI模式执行php文件
- foreach时,添加元素 或 修改元素的值
- 功能点 代码实现
- 生成url目录树(没有pid)
- 多图上传(vue传base64)
- 下载文件,耗时算法
- 生成商品二维码
- 导出excel
- 搜索
- 阿里大鱼发短信
- 使用阿里云oss
- location.href跳转后,丢失用户的session
- “\r ” “\r\n” “\t”的区别
- php的配置文件详解
- 开启错误日志
- 开启慢日志
- 开启短标签
- 分析php-fpm.conf中的request_terminate_timeout参数