detection-business/components/Rboy-editor/Rboy-editor.vue
2025-08-08 14:27:37 +08:00

131 lines
2.8 KiB
Vue

<template>
<div>
<view class="fu_box">
<editor style="border: none;" id="editor" :show-img-toolbar="true" :show-img-resize="true" :show-img-size="true" class=""
:placeholder="placeholder"></editor>
</view>
<view class="icons_box">
<text class="iconfont icon-zuoduiqi" @click="editor_format_btn('align','left')"></text>
<text class="iconfont icon-juzhongduiqi" @click="editor_format_btn('align','center')"></text>
<text class="iconfont icon-youduiqi" @click="editor_format_btn('align','right')"></text>
<text class="iconfont icon-zuoyouduiqi" @click="editor_format_btn('align','justify')">
</text>
<text class="iconfont icon-zitijiacu" @click="editor_format_btn('bold')"></text>
<text class="iconfont icon-zitixieti" @click="editor_format_btn('italic')"></text>
<text class="iconfont icon-charutupian" @click="editor_img_btn"></text>
</view>
</div>
</template>
<script>
export default {
name: "Rboy-editor",
props: {
count: {
type: Number,
default: 6
},
newsContent:{
type:String,
default:''
}
},
data() {
return {
editorCtx: '',
placeholder:'请输入详情'
}
},
created() {
},
mounted() {
let that = this
uni.createSelectorQuery().in(this).select('#editor').context((res2) => {
that.editorCtx = res2.context
}).exec()
},
onShow() {
},
methods: {
// 获取内容
editor_getcontents() {
return new Promise((resove, reject) => {
this.editorCtx.getContents({
success: (res) => {
resove(res.html)
}
})
})
},
// 设置内容
editor_setContents() {
if(this.editorCtx){
this.editorCtx.setContents({
html: this.newsContent //this.EditGoodsDetail.content为赋值内容。
})
}
},
// 设置内容
editor_setContentsNew(content) {
if(this.editorCtx){
this.editorCtx.setContents({
html: content //this.EditGoodsDetail.content为赋值内容。
})
}
},
// 设置属性
editor_format_btn(name, value) {
this.editorCtx.format(name, value)
},
// 设置图片
editor_insertImage(data) {
if (!data) return false
this.editorCtx.insertImage(data)
},
// 上传图片
editor_img_btn() {
uni.chooseImage({
count: this.count || 6, // 控制上传图片的数量 默认 6
type: 'image',
success: async (res) => {
this.$emit("uploadFile", res)
}
});
},
}
}
</script>
<style scoped lang="less">
@import './editor-icon.css';
.fu_box {
min-height: 35px !important;
border:none;
border-radius: 4px;
font-size: 14px;
width: 100%;
box-sizing: border-box;
text-align: left;
color: #333;
padding: 7px;
editor {
width: 100%;
}
}
.icons_box {
font-size: 18px;
.iconfont {
margin: 5rpx 10rpx;
font-size: 24px !important;
}
}
</style>