131 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
		
		
			
		
	
	
			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> |