Welcom to 评论 - lizhenqiu blog!
#248
#249
#250
#251
#252
#253
#254
$media = new Media($this->app); $getBroadcastInfoUrl = $media->getBroadcastInfoUrl($content->media_id);
#255
<!DOCTYPE html> <html> <head> <title>内容演示</title> <meta http-equiv="content-type" content="text/html; charset=UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" /> <meta name="apple-mobile-web-app-capable" content="yes" /> <meta name="apple-mobile-web-app-status-bar-style" content="black" /> <meta name="format-detection" content="telephone=no" /> <style> *{color: #fff;padding: 0px;margin: 0px;border: 0px;} img{max-width: 100%;} </style> </head> <body> {$content|raw|htmlspecialchars_decode} </body> </html>
#256
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>内容预览</title> <meta name="description" content=""> <meta name="keywords" content=""> <meta name="viewport" content="initial-scale=1, maximum-scale=1"> <meta name="apple-mobile-web-app-capable" content="yes"> <meta name="apple-mobile-web-app-status-bar-style" content="black"> </head> <body class="docs-home" ontouchstart=""> <style type="text/css"> @media (min-width: 850px){ .docs-home .phone{ /*margin: 0px 0px;*/ margin: 10px auto !important; } .phone:before { content: ''; width: 60px; height: 10px; border-radius: 10px; position: absolute; left:50%; margin-left: -30px; background:#333; top: 50px; } .phone .statusbar { position: absolute; width: 320px; height: 20px; background:url(''); left: 50%; margin-left: -160px; top: 100px; -webkit-background-size: 100% auto; background-size: 100% auto; } .phone:after { content: ''; position: absolute; width: 60px; height: 60px; left: 50%; margin-left: -30px; bottom: 20px; border-radius: 100%; box-sizing: border-box; border: 5px solid #333; } } .phone{ background: #111; border-radius: 0px; box-shadow: none; width: 100%; height: 568px; padding: 0; } .docs-home.mui-ios .phone .statusbar,.docs-home.mui-android .phone .statusbar,.docs-home.mui-ios .phone:before,.docs-home.mui-ios .phone:after{ display: none; } .phone { margin: 0 auto; position: relative; background: #111; border-radius: 55px; box-shadow: 0px 0px 0px 2px #aaa; width: 320px; height: 568px; padding: 105px 25px; -webkit-box-sizing: content-box; box-sizing: content-box; } .phone iframe { width: 320px; height: 100%; display: block; width: 100%; margin-top: 20px; } </style> <div class="docs-header"> <div style="max-width:1024px;margin:0 auto;"> <div class="phone"> <iframe src="" frameborder="0" scrolling="yes" id="myframe"></iframe> <div class="statusbar"></div> </div> </div> </div> <script> document.getElementById("myframe").src=getQueryVariable('uf'); function getQueryVariable(variable) { var query = window.location.search.substring(1); var vars = query.split("&"); for (var i=0;i<vars.length;i++) { var pair = vars[i].split("="); if(pair[0] == variable){return pair[1];} } return(false); } </script> </body> </html>
#257
//返回文章内容 public function rHtml(){ $param = $this->request->param(); if(isset($param['id']) && $param['id']) $id=$param['id']; else exit('no id'); $content=ArticlesModel::find($id); // 模板输出并变量赋值 return View::fetch('runhtml', [ 'content' => $content->content ]); } public function runM(){ return View::fetch('runM'); }
#258
#259
cd/ e: cd Php-project\jxt\view\group npm run dev pause
#260
cd/ e: cd test1/test2
#261
<el-upload class="avatar-uploader el-upload--text" :action="uploadUrl" :show-file-list="false" :on-success="handleVideoSuccess" :before-upload="beforeUploadVideo" :on-progress="uploadVideoProcess">
uploadVideoProcess(event, file, fileList){ this.videoFlag = true; this.videoUploadPercent = file.percentage.toFixed(0); },
#262
<el-upload class="upload-demo" action="#" ref="upimg" :on-success="handleAvatarSuccess" :on-progress="uploadVideoProcess" :http-request="httpRequestLogo" :limit="1" > <el-button size="mini" type="primary">点击上传</el-button> <!-- <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div> --> </el-upload>
handleAvatarSuccess(res, file) { //console.log(213); // this.myData= file; this.$refs.upimg.clearFiles(); //上传成功之后清除历史记录 //this.handleInitTableData(); //初始化表格数据 }, /*uploadVideoProcess(event, file, fileList){ console.log(file.percentage.toFixed(0)); },*/ // 图片上传 httpRequestLogo(file) { if('' === this.categoryprice) { return this.$message.error('请选择图片分类') } let formdata = new FormData() formdata.append('file',file.file) formdata.append('name',file.file.name) formdata.append('categoryId', this.categoryprice) this.loading=true; const config = { onUploadProgress: progressEvent => { // progressEvent.loaded:已上传文件大小 // progressEvent.total:被上传文件的总大小 let progressPercent = Number((progressEvent.loaded / progressEvent.total * 100).toFixed(2)) if(progressPercent>99) this.loading=false; this.progressPercent=progressPercent; //console.log(progressPercent); } } this.$http.post('/image/upload', formdata,config).then(({ data: res }) => { console.log(res) if(1 !== res.code) { return this.$message.error(res.msg) } this.$message.success('上传成功') this.handleAvatarSuccess() this.getDataList() }) },
#263
chmod 777 项目文件夹/node_modules/.bin/vue-cli-service
#264
<!--配置文件 value: //编辑器内容 config:{ eddc:{ //其他 }, toolbars:[ //工具栏] } editorNum: 1 //编辑器编号 width: 75% width1: 380px --> <template> <!--<script id="editor" type="text/plain"></script>--> <div> <div :id="'editor'+editorNum"></div> <JxtPicture :exhibition="exhibition" @close="onClose" :title="'图片管理'" @getImg="getImg" :width="'75%'" :width1="'380px'" :priceLength="10000" v-if="exhibition" ></JxtPicture> </div> </template> <script> import JxtPicture from '../components/jxt-picture.vue' export default { name: 'ue1', components: { JxtPicture }, props: { editorNum:{ type: Number, default:1 //编辑器编号 }, value: { type: String, default: '', required: false }, config: { type: Object, default: { eddc:{}, toolbars:[] }, required: false }, }, data() { return { exhibition:false, editor: null, instance: null, //texta: 333, configd:this.config, eddc:{ initialFrameWidth:null ,//宽度随浏览器自适应 wordCount: false, //关闭字数统计 elementPathEnabled : false,//隐藏元素路径 autoHeightEnabled: true,//是否自动长高 autoFloatEnabled: true,//是否保持toolbar的位置不动 initialFrameHeight: 360, }, toolbars: [[ 'source', //源代码 //'anchor', //锚点 'undo', //撤销 'redo', //重做 '|', 'forecolor', //字体颜色 'backcolor', //背景色 'bold', //加粗 //'indent', //首行缩进 //'snapscreen', //截图 'italic', //斜体 'underline', //下划线 'strikethrough', //删除线 'subscript', //下标 'fontborder', //字符边框 'superscript', //上标 '|', 'formatmatch', //格式刷 //'blockquote', //引用 'pasteplain', //纯文本粘贴模式 'selectall', //全选 //'print', //打印 //'preview', //预览 'horizontal', //分隔线 'removeformat', //清除格式 '|', //'time', //时间 //'date', //日期 //'unlink', //取消链接 'insertrow', //前插入行 'insertcol', //前插入列 'mergeright', //右合并单元格 'mergedown', //下合并单元格 'deleterow', //删除行 'deletecol', //删除列 'splittorows', //拆分成行 'splittocols', //拆分成列 'splittocells', //完全拆分单元格 'deletecaption', //删除表格标题 'inserttitle', //插入标题 'mergecells', //合并多个单元格 'deletetable', //删除表格 'cleardoc', //清空文档 //'insertparagraphbeforetable', //"表格前插入行" //'insertcode', //代码语言 //'fontfamily', //字体 '|', 'fontsize', //字号 'paragraph', //段落格式 //'simpleupload', //单图上传 //'insertimage', //多图上传 //'edittable', //表格属性 //'edittd', //单元格属性 //'link', //超链接 //'emotion', //表情 //'spechars', //特殊字符 //'searchreplace', //查询替换 //'map', //Baidu地图 //'gmap', //Google地图 //'insertvideo', //视频 //'help', //帮助 '|', 'justifyleft', //居左对齐 'justifyright', //居右对齐 'justifycenter', //居中对齐 'justifyjustify', //两端对齐 '|', 'insertorderedlist', //有序列表 'insertunorderedlist', //无序列表 //'directionalityltr', //从左向右输入 //'directionalityrtl', //从右向左输入 //'rowspacingtop', //段前距 //'rowspacingbottom', //段后距 'pagebreak', //分页 'insertframe', //插入Iframe '|', 'imagenone', //默认 'imageleft', //左浮动 'imageright', //右浮动 //'attachment', //附件 'imagecenter', //居中 //'wordimage', //图片转存 'lineheight', //行间距 //'edittip ', //编辑提示 //'customstyle', //自定义标题 //'autotypeset', //自动排版 //'webapp', //百度应用 //'touppercase', //字母大写 //'tolowercase', //字母小写 //'background', //背景 //'template', //模板 //'scrawl', //涂鸦 //'music', //音乐 'inserttable', //插入表格 //'drafts', // 从草稿箱加载 'charts', // 图表 '|', 'fullscreen', //全屏 'macros', // 自定义上传 ]] } }, watch: { value: { handler: function(val, oldVal) { this.editor = window.UE.getEditor('editor'+this.editorNum, this.configd); this.editor.setContent(val); } } }, mounted () { let config=this.config; //console.log(config.eddc);return false; let eddc=config.eddc && Object.keys(config.eddc).length!=0?config.eddc:this.eddc let toolbars=config.toolbars && config.toolbars.length && config.toolbars[0] && config.toolbars[0].length ?config.toolbars:this.toolbars //console.log(eddc); eddc.toolbars=toolbars; console.log(eddc) this.configd=eddc; this.$nextTick(() => { const _this = this this.editor = window.UE.getEditor('editor'+this.editorNum, this.configd); this.editor.addListener('ready', function () { _this.editor.setContent(_this.value) }) this.editor.commands['macros'] = { execCommand : () => { this.beforeInsertImage() }, queryCommandState: function(){ } } }) }, methods: { onClose() { this.exhibition = false }, getUEContent () { return this.editor.getContent() }, beforeInsertImage() { //this.$emit('showModal', { editor: 'editor' }) //console.log(e) this.exhibition = true //this.priceLength = 10000 }, getImg(e) { let UE = this.editor e.forEach(item => { UE.execCommand('insertHtml', `<img src=${item.org_img}>`) }) }, }, destroyed () { this.editor.destroy() } } </script> <style lang="scss" scoped> /*#editor { width: 90vh; }*/ </style>
#265
<script type="text/javascript" src="ueditor/ueditor.config.js"></script> <script type="text/javascript" src="ueditor/ueditor.all.min.js"> </script> <script type="text/javascript" src="ueditor/lang/zh-cn/zh-cn.js"></script> <script> $(function() { //本来是这样的:UE.getEditor('editor'); 传入参数后就是下面那样子了,toolbars里的就是工具的图标 UE.getEditor('editor', { toolbar: [ ['fullscreen', 'source', 'undo', 'redo', 'bold', 'italic', 'underline','fontborder', 'backcolor', 'fontsize', 'fontfamily', 'justifyleft', 'justifyright','justifycenter', 'justifyjustify', 'strikethrough','superscript', 'subscript', 'removeformat', 'formatmatch','autotypeset', 'blockquote', 'pasteplain', '|', 'forecolor', 'backcolor','insertorderedlist', 'insertunorderedlist', 'selectall', 'cleardoc', 'link', 'unlink','emotion', 'help'] ] }); }) </script>
'|'
toolbars: [ [ 'anchor', //锚点 'undo', //撤销 'redo', //重做 'bold', //加粗 'indent', //首行缩进 'snapscreen', //截图 'italic', //斜体 'underline', //下划线 'strikethrough', //删除线 'subscript', //下标 'fontborder', //字符边框 'superscript', //上标 'formatmatch', //格式刷 'source', //源代码 'blockquote', //引用 'pasteplain', //纯文本粘贴模式 'selectall', //全选 'print', //打印 'preview', //预览 'horizontal', //分隔线 'removeformat', //清除格式 'time', //时间 'date', //日期 'unlink', //取消链接 'insertrow', //前插入行 'insertcol', //前插入列 'mergeright', //右合并单元格 'mergedown', //下合并单元格 'deleterow', //删除行 'deletecol', //删除列 'splittorows', //拆分成行 'splittocols', //拆分成列 'splittocells', //完全拆分单元格 'deletecaption', //删除表格标题 'inserttitle', //插入标题 'mergecells', //合并多个单元格 'deletetable', //删除表格 'cleardoc', //清空文档 'insertparagraphbeforetable', //"表格前插入行" 'insertcode', //代码语言 'fontfamily', //字体 'fontsize', //字号 'paragraph', //段落格式 'simpleupload', //单图上传 'insertimage', //多图上传 'edittable', //表格属性 'edittd', //单元格属性 'link', //超链接 'emotion', //表情 'spechars', //特殊字符 'searchreplace', //查询替换 'map', //Baidu地图 'gmap', //Google地图 'insertvideo', //视频 'help', //帮助 'justifyleft', //居左对齐 'justifyright', //居右对齐 'justifycenter', //居中对齐 'justifyjustify', //两端对齐 'forecolor', //字体颜色 'backcolor', //背景色 'insertorderedlist', //有序列表 'insertunorderedlist', //无序列表 'fullscreen', //全屏 'directionalityltr', //从左向右输入 'directionalityrtl', //从右向左输入 'rowspacingtop', //段前距 'rowspacingbottom', //段后距 'pagebreak', //分页 'insertframe', //插入Iframe 'imagenone', //默认 'imageleft', //左浮动 'imageright', //右浮动 'attachment', //附件 'imagecenter', //居中 'wordimage', //图片转存 'lineheight', //行间距 'edittip ', //编辑提示 'customstyle', //自定义标题 'autotypeset', //自动排版 'webapp', //百度应用 'touppercase', //字母大写 'tolowercase', //字母小写 'background', //背景 'template', //模板 'scrawl', //涂鸦 'music', //音乐 'inserttable', //插入表格 'drafts', // 从草稿箱加载 'charts', // 图表 ] ]
<!-- 加载编辑器的容器 --> <script id="editor" type="text/plain" name="content"> ${info.content} //在这里输入编辑器的初始内容。 </script> <!-- 创建编辑器并设置属性 --> <script type="text/javascript"> //建议使用工厂方法getEditor创建和引用编辑器实例,如果在某个闭包下引用该编辑器,直接调用UE.getEditor('editor')就能拿到相关的实例 //相见文档配置属于你自己的编译器 var ue = UE.getEditor('editor', { initialFrameHeight: 300, initialFrameWeight: 100 }); </script>
#266
确定要清除编辑框内容吗?
该删除操作将不可恢复。
删除 取消
激活Windows
转到"设置"以激活Windows。
#248
#249
#250
一证通查入口 电脑端
#251
#252
#253
#254
$media = new Media($this->app); $getBroadcastInfoUrl = $media->getBroadcastInfoUrl($content->media_id);#255
<!DOCTYPE html> <html> <head> <title>内容演示</title> <meta http-equiv="content-type" content="text/html; charset=UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" /> <meta name="apple-mobile-web-app-capable" content="yes" /> <meta name="apple-mobile-web-app-status-bar-style" content="black" /> <meta name="format-detection" content="telephone=no" /> <style> *{color: #fff;padding: 0px;margin: 0px;border: 0px;} img{max-width: 100%;} </style> </head> <body> {$content|raw|htmlspecialchars_decode} </body> </html>#256
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>内容预览</title> <meta name="description" content=""> <meta name="keywords" content=""> <meta name="viewport" content="initial-scale=1, maximum-scale=1"> <meta name="apple-mobile-web-app-capable" content="yes"> <meta name="apple-mobile-web-app-status-bar-style" content="black"> </head> <body class="docs-home" ontouchstart=""> <style type="text/css"> @media (min-width: 850px){ .docs-home .phone{ /*margin: 0px 0px;*/ margin: 10px auto !important; } .phone:before { content: ''; width: 60px; height: 10px; border-radius: 10px; position: absolute; left:50%; margin-left: -30px; background:#333; top: 50px; } .phone .statusbar { position: absolute; width: 320px; height: 20px; background:url(''); left: 50%; margin-left: -160px; top: 100px; -webkit-background-size: 100% auto; background-size: 100% auto; } .phone:after { content: ''; position: absolute; width: 60px; height: 60px; left: 50%; margin-left: -30px; bottom: 20px; border-radius: 100%; box-sizing: border-box; border: 5px solid #333; } } .phone{ background: #111; border-radius: 0px; box-shadow: none; width: 100%; height: 568px; padding: 0; } .docs-home.mui-ios .phone .statusbar,.docs-home.mui-android .phone .statusbar,.docs-home.mui-ios .phone:before,.docs-home.mui-ios .phone:after{ display: none; } .phone { margin: 0 auto; position: relative; background: #111; border-radius: 55px; box-shadow: 0px 0px 0px 2px #aaa; width: 320px; height: 568px; padding: 105px 25px; -webkit-box-sizing: content-box; box-sizing: content-box; } .phone iframe { width: 320px; height: 100%; display: block; width: 100%; margin-top: 20px; } </style> <div class="docs-header"> <div style="max-width:1024px;margin:0 auto;"> <div class="phone"> <iframe src="" frameborder="0" scrolling="yes" id="myframe"></iframe> <div class="statusbar"></div> </div> </div> </div> <script> document.getElementById("myframe").src=getQueryVariable('uf'); function getQueryVariable(variable) { var query = window.location.search.substring(1); var vars = query.split("&"); for (var i=0;i<vars.length;i++) { var pair = vars[i].split("="); if(pair[0] == variable){return pair[1];} } return(false); } </script> </body> </html>#257
//返回文章内容 public function rHtml(){ $param = $this->request->param(); if(isset($param['id']) && $param['id']) $id=$param['id']; else exit('no id'); $content=ArticlesModel::find($id); // 模板输出并变量赋值 return View::fetch('runhtml', [ 'content' => $content->content ]); } public function runM(){ return View::fetch('runM'); }#258
#259
cd/ e: cd Php-project\jxt\view\group npm run dev pause#260
cd/ e: cd test1/test2#261
<el-upload class="avatar-uploader el-upload--text" :action="uploadUrl" :show-file-list="false" :on-success="handleVideoSuccess" :before-upload="beforeUploadVideo" :on-progress="uploadVideoProcess">uploadVideoProcess(event, file, fileList){ this.videoFlag = true; this.videoUploadPercent = file.percentage.toFixed(0); },#262
<el-upload class="upload-demo" action="#" ref="upimg" :on-success="handleAvatarSuccess" :on-progress="uploadVideoProcess" :http-request="httpRequestLogo" :limit="1" > <el-button size="mini" type="primary">点击上传</el-button> <!-- <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过500kb</div> --> </el-upload>handleAvatarSuccess(res, file) { //console.log(213); // this.myData= file; this.$refs.upimg.clearFiles(); //上传成功之后清除历史记录 //this.handleInitTableData(); //初始化表格数据 }, /*uploadVideoProcess(event, file, fileList){ console.log(file.percentage.toFixed(0)); },*/ // 图片上传 httpRequestLogo(file) { if('' === this.categoryprice) { return this.$message.error('请选择图片分类') } let formdata = new FormData() formdata.append('file',file.file) formdata.append('name',file.file.name) formdata.append('categoryId', this.categoryprice) this.loading=true; const config = { onUploadProgress: progressEvent => { // progressEvent.loaded:已上传文件大小 // progressEvent.total:被上传文件的总大小 let progressPercent = Number((progressEvent.loaded / progressEvent.total * 100).toFixed(2)) if(progressPercent>99) this.loading=false; this.progressPercent=progressPercent; //console.log(progressPercent); } } this.$http.post('/image/upload', formdata,config).then(({ data: res }) => { console.log(res) if(1 !== res.code) { return this.$message.error(res.msg) } this.$message.success('上传成功') this.handleAvatarSuccess() this.getDataList() }) },#263
chmod 777 项目文件夹/node_modules/.bin/vue-cli-service#264
<!--配置文件 value: //编辑器内容 config:{ eddc:{ //其他 }, toolbars:[ //工具栏] } editorNum: 1 //编辑器编号 width: 75% width1: 380px --> <template> <!--<script id="editor" type="text/plain"></script>--> <div> <div :id="'editor'+editorNum"></div> <JxtPicture :exhibition="exhibition" @close="onClose" :title="'图片管理'" @getImg="getImg" :width="'75%'" :width1="'380px'" :priceLength="10000" v-if="exhibition" ></JxtPicture> </div> </template> <script> import JxtPicture from '../components/jxt-picture.vue' export default { name: 'ue1', components: { JxtPicture }, props: { editorNum:{ type: Number, default:1 //编辑器编号 }, value: { type: String, default: '', required: false }, config: { type: Object, default: { eddc:{}, toolbars:[] }, required: false }, }, data() { return { exhibition:false, editor: null, instance: null, //texta: 333, configd:this.config, eddc:{ initialFrameWidth:null ,//宽度随浏览器自适应 wordCount: false, //关闭字数统计 elementPathEnabled : false,//隐藏元素路径 autoHeightEnabled: true,//是否自动长高 autoFloatEnabled: true,//是否保持toolbar的位置不动 initialFrameHeight: 360, }, toolbars: [[ 'source', //源代码 //'anchor', //锚点 'undo', //撤销 'redo', //重做 '|', 'forecolor', //字体颜色 'backcolor', //背景色 'bold', //加粗 //'indent', //首行缩进 //'snapscreen', //截图 'italic', //斜体 'underline', //下划线 'strikethrough', //删除线 'subscript', //下标 'fontborder', //字符边框 'superscript', //上标 '|', 'formatmatch', //格式刷 //'blockquote', //引用 'pasteplain', //纯文本粘贴模式 'selectall', //全选 //'print', //打印 //'preview', //预览 'horizontal', //分隔线 'removeformat', //清除格式 '|', //'time', //时间 //'date', //日期 //'unlink', //取消链接 'insertrow', //前插入行 'insertcol', //前插入列 'mergeright', //右合并单元格 'mergedown', //下合并单元格 'deleterow', //删除行 'deletecol', //删除列 'splittorows', //拆分成行 'splittocols', //拆分成列 'splittocells', //完全拆分单元格 'deletecaption', //删除表格标题 'inserttitle', //插入标题 'mergecells', //合并多个单元格 'deletetable', //删除表格 'cleardoc', //清空文档 //'insertparagraphbeforetable', //"表格前插入行" //'insertcode', //代码语言 //'fontfamily', //字体 '|', 'fontsize', //字号 'paragraph', //段落格式 //'simpleupload', //单图上传 //'insertimage', //多图上传 //'edittable', //表格属性 //'edittd', //单元格属性 //'link', //超链接 //'emotion', //表情 //'spechars', //特殊字符 //'searchreplace', //查询替换 //'map', //Baidu地图 //'gmap', //Google地图 //'insertvideo', //视频 //'help', //帮助 '|', 'justifyleft', //居左对齐 'justifyright', //居右对齐 'justifycenter', //居中对齐 'justifyjustify', //两端对齐 '|', 'insertorderedlist', //有序列表 'insertunorderedlist', //无序列表 //'directionalityltr', //从左向右输入 //'directionalityrtl', //从右向左输入 //'rowspacingtop', //段前距 //'rowspacingbottom', //段后距 'pagebreak', //分页 'insertframe', //插入Iframe '|', 'imagenone', //默认 'imageleft', //左浮动 'imageright', //右浮动 //'attachment', //附件 'imagecenter', //居中 //'wordimage', //图片转存 'lineheight', //行间距 //'edittip ', //编辑提示 //'customstyle', //自定义标题 //'autotypeset', //自动排版 //'webapp', //百度应用 //'touppercase', //字母大写 //'tolowercase', //字母小写 //'background', //背景 //'template', //模板 //'scrawl', //涂鸦 //'music', //音乐 'inserttable', //插入表格 //'drafts', // 从草稿箱加载 'charts', // 图表 '|', 'fullscreen', //全屏 'macros', // 自定义上传 ]] } }, watch: { value: { handler: function(val, oldVal) { this.editor = window.UE.getEditor('editor'+this.editorNum, this.configd); this.editor.setContent(val); } } }, mounted () { let config=this.config; //console.log(config.eddc);return false; let eddc=config.eddc && Object.keys(config.eddc).length!=0?config.eddc:this.eddc let toolbars=config.toolbars && config.toolbars.length && config.toolbars[0] && config.toolbars[0].length ?config.toolbars:this.toolbars //console.log(eddc); eddc.toolbars=toolbars; console.log(eddc) this.configd=eddc; this.$nextTick(() => { const _this = this this.editor = window.UE.getEditor('editor'+this.editorNum, this.configd); this.editor.addListener('ready', function () { _this.editor.setContent(_this.value) }) this.editor.commands['macros'] = { execCommand : () => { this.beforeInsertImage() }, queryCommandState: function(){ } } }) }, methods: { onClose() { this.exhibition = false }, getUEContent () { return this.editor.getContent() }, beforeInsertImage() { //this.$emit('showModal', { editor: 'editor' }) //console.log(e) this.exhibition = true //this.priceLength = 10000 }, getImg(e) { let UE = this.editor e.forEach(item => { UE.execCommand('insertHtml', `<img src=${item.org_img}>`) }) }, }, destroyed () { this.editor.destroy() } } </script> <style lang="scss" scoped> /*#editor { width: 90vh; }*/ </style>#265
UEditor自定义toolbar工具条
使用ueditor的同学都知道,ueditor里有很多功能,
很全面,但有时候我们的编辑器不需要太多的功能,比如前台评论或者留言,就不需要这么多功能了,
那我们怎么去定制自己想要的工具呢?
官方给出了两个方法,
ueditor工具栏上的按钮列表可以自定义配置,
只需要通过修改配置项就可以实现需求:
1. 方法一:修改ueditorconfig.js里面的toolbars
2. 方法二:实例化编辑器的时候传入toolbars参数
第一种貌似不适合,需要改ueditor.config.js文件,有点麻烦,
第二种就很好,我们且来看看第二种方法,示例如下:
<script type="text/javascript" src="ueditor/ueditor.config.js"></script> <script type="text/javascript" src="ueditor/ueditor.all.min.js"> </script> <script type="text/javascript" src="ueditor/lang/zh-cn/zh-cn.js"></script> <script> $(function() { //本来是这样的:UE.getEditor('editor'); 传入参数后就是下面那样子了,toolbars里的就是工具的图标 UE.getEditor('editor', { toolbar: [ ['fullscreen', 'source', 'undo', 'redo', 'bold', 'italic', 'underline','fontborder', 'backcolor', 'fontsize', 'fontfamily', 'justifyleft', 'justifyright','justifycenter', 'justifyjustify', 'strikethrough','superscript', 'subscript', 'removeformat', 'formatmatch','autotypeset', 'blockquote', 'pasteplain', '|', 'forecolor', 'backcolor','insertorderedlist', 'insertunorderedlist', 'selectall', 'cleardoc', 'link', 'unlink','emotion', 'help'] ] }); }) </script>配置项里用竖线
'|'完整的按钮列表
toolbars: [ [ 'anchor', //锚点 'undo', //撤销 'redo', //重做 'bold', //加粗 'indent', //首行缩进 'snapscreen', //截图 'italic', //斜体 'underline', //下划线 'strikethrough', //删除线 'subscript', //下标 'fontborder', //字符边框 'superscript', //上标 'formatmatch', //格式刷 'source', //源代码 'blockquote', //引用 'pasteplain', //纯文本粘贴模式 'selectall', //全选 'print', //打印 'preview', //预览 'horizontal', //分隔线 'removeformat', //清除格式 'time', //时间 'date', //日期 'unlink', //取消链接 'insertrow', //前插入行 'insertcol', //前插入列 'mergeright', //右合并单元格 'mergedown', //下合并单元格 'deleterow', //删除行 'deletecol', //删除列 'splittorows', //拆分成行 'splittocols', //拆分成列 'splittocells', //完全拆分单元格 'deletecaption', //删除表格标题 'inserttitle', //插入标题 'mergecells', //合并多个单元格 'deletetable', //删除表格 'cleardoc', //清空文档 'insertparagraphbeforetable', //"表格前插入行" 'insertcode', //代码语言 'fontfamily', //字体 'fontsize', //字号 'paragraph', //段落格式 'simpleupload', //单图上传 'insertimage', //多图上传 'edittable', //表格属性 'edittd', //单元格属性 'link', //超链接 'emotion', //表情 'spechars', //特殊字符 'searchreplace', //查询替换 'map', //Baidu地图 'gmap', //Google地图 'insertvideo', //视频 'help', //帮助 'justifyleft', //居左对齐 'justifyright', //居右对齐 'justifycenter', //居中对齐 'justifyjustify', //两端对齐 'forecolor', //字体颜色 'backcolor', //背景色 'insertorderedlist', //有序列表 'insertunorderedlist', //无序列表 'fullscreen', //全屏 'directionalityltr', //从左向右输入 'directionalityrtl', //从右向左输入 'rowspacingtop', //段前距 'rowspacingbottom', //段后距 'pagebreak', //分页 'insertframe', //插入Iframe 'imagenone', //默认 'imageleft', //左浮动 'imageright', //右浮动 'attachment', //附件 'imagecenter', //居中 'wordimage', //图片转存 'lineheight', //行间距 'edittip ', //编辑提示 'customstyle', //自定义标题 'autotypeset', //自动排版 'webapp', //百度应用 'touppercase', //字母大写 'tolowercase', //字母小写 'background', //背景 'template', //模板 'scrawl', //涂鸦 'music', //音乐 'inserttable', //插入表格 'drafts', // 从草稿箱加载 'charts', // 图表 ] ]备注:
我配置的时候配置key使用的是toolbar,
很多博文使用的是toolbars,但是我使用toolbars不起作用,
不知道是不是ueditor的版本问题。
<!-- 加载编辑器的容器 --> <script id="editor" type="text/plain" name="content"> ${info.content} //在这里输入编辑器的初始内容。 </script> <!-- 创建编辑器并设置属性 --> <script type="text/javascript"> //建议使用工厂方法getEditor创建和引用编辑器实例,如果在某个闭包下引用该编辑器,直接调用UE.getEditor('editor')就能拿到相关的实例 //相见文档配置属于你自己的编译器 var ue = UE.getEditor('editor', { initialFrameHeight: 300, initialFrameWeight: 100 }); </script>#266