关于在vue 中使用百度ueEditor
2018-09-18 06:39:24来源:博客园 阅读 ()
1. 安装 npm i vue-ueditor --save-dev
2.从nodemodels 取出ueditor1_4_3_3 这整个目录,放入vue 的 static 目录
3.配置 ueditor.config.js 的 21行代码 更改路径 var URL = '/static/ueditor1_4_3_3/' || getUEBasePath();
(1) serverUrl: URL + 'php/controller.php', 这里是你配置的上传内容的 url ;不需要可以删除;
(2) 部分人使用时出现以下报错: Uncaught TypeError: 'caller', 'callee', and 'arguments' properties may not be accessed on strict mode functions or the arguments objects for calls to them...
这个问题是因为项目中的使用的babel默认添加了use strict造成,可参考 https://segmentfault.com/q/1010000007415253
我采用的是链接中答案的第三种方式:添加了babel-plugin-transform-remove-strict-mode,并在.babelrc里添加下列代码;
2-1.1 或者在webpack.base.conf.js 添加
loaders: [{
test: /\.js$/,
exclude: /(node_modules|bower_components)/,
loader: 'babel',
query: {
presets: ['es2015']
}}]
4.如果不需要以组建的方式引入 则 可以这么写 ;
<VueUeditor ueditorPath="./../../static/ueditor/" @ready="editorReady"></VueUeditor>
<script> import VueUeditor from 'vue-ueditor'; import ueditor from '../components/UE'; export default { components: {VueUeditor,ueditor}, data() { return { defaultMsg: '这里是UE测试', content1: '这里是UE', ue1: "ue1", config: { initialFrameWidth: 800, initialFrameHeight: 350 } } }, methods: { getUEContent() { // 获取ueditor值 let content1 = UE.getEditor(this.ue1).getContentTxt();; console.log(content1) }, editorReady(editorInstance){ editorInstance.setContent("哈哈哈") } } };
5.如果要自定义组件的方式 在每个页面引入 则 在components 中新建ue.vue 文件 贴入这个代码
<template> <script :id=id type="text/plain"></script> </template> <script> export default { name: 'UE', data() { return { editor: null } }, props: { content: { type: String, default:'' }, config: { type: Object, }, id: { type: String } }, mounted() { const _this = this; _this.editor = UE.getEditor(_this.id, _this.config); // 初始化UE _this.editor.addListener("ready", function () { _this.editor.setContent(_this.content); // 确保UE加载完成后,放入内容。 }); }, methods: { getContent() { // 获取内容方法 return this.editor.getContentTxt();; } }, destroyed() { this.editor.destroy(); }, } </script>
然后就可以 import ueditor from '../components/UE'; //引入
<ueditor :content=content1 :config=config :id="ue1"></ueditor> //使用
<script> import VueUeditor from 'vue-ueditor'; import ueditor from '../components/UE'; export default { components: {VueUeditor,ueditor}, data() { return { defaultMsg: '这里是UE测试', content1: '这里是UE', ue1: "ue1", config: { initialFrameWidth: 800, initialFrameHeight: 350 } } }, methods: { getUEContent() { // 获取ueditor值 let content1 = UE.getEditor(this.ue1).getContentTxt();; console.log(content1) }, editorReady(editorInstance){ editorInstance.setContent("哈哈哈") } } }; </script>
这样就可以了。
附配置清单
1. 实例化编辑器到id为 container 的 dom 容器上: var ue = UE.getEditor('container'); 2. 设置编辑器内容: ue.setContent('<p>hello!</p>'); 3. 追加编辑器内容: ue.setContent('<p>new text</p>', true); 4. 获取编辑器html内容: var html = ue.getContent(); 5. 获取纯文本内容: ue.getContentTxt(); 6. 获取保留格式的文本内容: ue.getPlainTxt(); 7. 判断编辑器是否有内容: ue.hasContents(); 8. 让编辑器获得焦点: ue.focus(); 9. 让编辑器失去焦点 ue.blur(); 10. 判断编辑器是否获得焦点: ue.isFocus(); 11. 设置当前编辑区域不可编辑: ue.setDisabled(); 12. 设置当前编辑区域可以编辑: ue.setEnabled(); 13. 隐藏编辑器: ue.setHide(); 14. 显示编辑器: ue.setShow(); 15. 清空内容: ue.execCommand('cleardoc'); 16. 读取草稿箱: ue.execCommand('drafts'); 17. 清空草稿箱: ue.execCommand('clearlocaldata');
本来需求是 从后台读取文件内容,内容是代码,返回到前台,高亮显示像 ide一样可以实时编辑代码,代码可以高亮,类似编辑器的主题一样,然后可以保存提交 到后台,找了半天没找到合适的插件;
如果有推荐的欢迎Q我 qq735675958,一起交流下.谢谢
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 关于jQuery UI 使用心得及技巧 2020-03-29
- js中去掉字串左右空格 2020-03-20
- Js中如何使用sort() 2020-03-18
- vue.js开发环境搭建教程 2020-03-16
- javascript 中关于array的常用方法详解 2020-03-16
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash