最近接手的项目中, 部分页面需要使用富文本编辑器, 对比了几款web富文本编辑器后, 综合兼容性和简洁性,最终我选择了 summernote, 详情见官方github地址 github–summernote本项目基于 vue2.0 , 使用 vue-cli 脚手架的 webpack 模板搭建, 整体项目目录如下:
data:image/s3,"s3://crabby-images/b2e8a/b2e8abbcc1a73459ce8c41f2196a68d4356bd323" alt=""
以下是具体使用 summernote 的流程:1. 在 package.json 文件中添加所需的依赖库,然后执行 npm install 安装这些库
data:image/s3,"s3://crabby-images/f7590/f75904fdc3126ac6ff4fb1bfec219a43cb08079c" alt=""
2. 在 src / main.js 文件中导入下列库文件
data:image/s3,"s3://crabby-images/a030d/a030d141129ba727eec02788703bd18829246a5c" alt=""
3. 由于summernote 使用 jQuery 库, 我们在组件里需要导入 jQuery才能使用, 为了方便起见,我们在 build / webpack.base.conf.js文件中的 resolve配置项 中添加一个 alias 指向jquery路径
data:image/s3,"s3://crabby-images/239a6/239a6b9c10bc64e97e3de741285869903e820812" alt=""
4. 在vue组件中引入元素
data:image/s3,"s3://crabby-images/9e5f0/9e5f04165529679428185b2d0eea91b5bad8755b" alt=""
5. 在vue组件的 mounted 生命周期钩子中初始化summernote
data:image/s3,"s3://crabby-images/d12f8/d12f89d56968d48128bbf90c284e8ea25745ed1f" alt=""
6. 自定义上传图片的方法, 收到图片地址 url 后插入到富文本编辑器
data:image/s3,"s3://crabby-images/f3462/f34621c06348bfddc9103150810bcb2f3c36fb62" alt=""
自定义的网络 API 文件如下:关于获取七牛token的后台接口实现,参考本专栏上一篇文章使用Element UI框架(基于vue2.0)的upload组件上传图片至七牛云
data:image/s3,"s3://crabby-images/64f5e/64f5e986caca205590a29b23685dc529e114b6f6" alt=""
7. 最终实现效果如下:
data:image/s3,"s3://crabby-images/bad24/bad24ccc5453c78e0c43c21f372d8314c0738619" alt=""