| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236 | <template><view class="gui-editor">	<view class="gui-border-b">		<textarea class="gui-editor-title" maxlength="-1" 		v-model="article.title" placeholder="# 请输入标题" auto-height />	</view>	<!-- 空内容提示 -->	<view v-if="article.contents.length < 1">		<text class="gui-color-gray gui-editor-empty">请点击下面的按钮,添加内容。</text>	</view>	<!-- 内容区域 -->	<view v-for="(item, index) in article.contents" :key="index" 	class="gui-editor-items">		<!-- 加粗 -->		<view v-if="item.type == 'h3'">			<textarea class="gui-editor-strong gui-border-box" 			:data-index="index" maxlength="-1" :focus="item.focusin" 			@input="graceEditorInput" :value="item.content" @blur="blur" 			placeholder="请输入标题" />		</view>		<!-- 普通文本 -->		<view v-else-if="item.type == 'txt'">			<textarea class="gui-editor-txt gui-border-box" 			maxlength="-1" @blur="blur" 			:data-index="index" :focus="item.focusin" 			@input="graceEditorInput" :value="item.content" 			placeholder="请填写文本内容" />		</view>		<!-- 居中文本 -->		<view v-else-if="item.type == 'center'" 		class="gui-flex gui-rows gui-justify-content-center" 		style="background-color:#F8F8F8; padding:20rpx;">			<input type="text" class="gui-editor-center" 			@blur="blur" maxlength="-1" :data-index="index" 			:focus="item.focusin" @input="graceEditorInput" 			:value="item.content" placeholder="请填写居中文本" />		</view>		<!-- 图片 -->		<view v-else-if="item.type == 'img'" 		class="gui-editor-img-wrap">			<image :src="item.content" class="gui-editor-img" 			:data-index="index" mode="aspectFit"></image>			<view v-if="item.error" 			class="gui-editor-img-error gui-flex gui-columns gui-justify-content-center">				<text class="gui-editor-img-error-text gui-block-text gui-text-center gui-icons"> 上传失败,请重试</text>			</view>		</view>		<!-- 引用 -->		<view v-else-if="item.type == 'quote'">			<textarea class="gui-editor-quote gui-border-box" 			maxlength="-1" @blur="blur" 			:data-index="index" @input="graceEditorInput" :focus="item.focusin" 			:value="item.content" placeholder="请输入引用内容" />		</view>		<!-- 代码 -->		<view v-else-if="item.type == 'code'">			<textarea class="gui-editor-quote gui-border-box" 			maxlength="-1" @blur="blur" 			style="height:300rpx;"			:data-index="index" @input="graceEditorInput" :focus="item.focusin" 			:value="item.content" placeholder="请输入代码" />		</view>		<!-- 加粗 -->		<view v-else-if="item.type == 'strong'">			<textarea class="gui-editor-strong gui-border-box" 			:data-index="index" maxlength="-1" :focus="item.focusin" 			@input="graceEditorInput" :value="item.content" @blur="blur" 			placeholder="请输入加粗内容" />		</view>		<!-- 链接 -->		<view v-else-if="item.type == 'link'">			<input type="text" class="gui-editor-link gui-border-box" 			:focus="item.focusin" 			:data-index="index" @input="graceEditorInput" @blur="blur" 			:value="item.content" placeholder="请输入连接地址" />		</view>		<!-- 分割 -->		<view v-else-if="item.type == 'spline'">			<text class="gui-editor-spline gui-block-text" 			:data-index="index">● ● ●</text>		</view>		<!-- 功能 -->		<view class="gui-flex gui-rows gui-justify-content-end gui-editor-item-btns-wrap">			<view class="gui-editor-item-btns" hover-class="gui-tap" 			:data-index="index" @tap="moveup">				<text class="gui-editor-item-btns-text gui-block-text gui-icons"> 上移</text>			</view>			<view class="gui-editor-item-btns" hover-class="gui-tap" 			:data-index="index" @tap="movedown">				<text class="gui-editor-item-btns-text gui-block-text gui-icons"> 下移</text>			</view>			<view class="gui-editor-item-btns" @tap="deleteItem" 			hover-class="gui-tap" :data-index="index">				<text class="gui-editor-item-btns-text gui-block-text gui-icons"> 删除</text>			</view>		</view>	</view>	<view class="gui-margin-top-large" 	v-if="article.contents.length >= 1"></view>	<!-- 选项类型选择 -->	<view class="gui-flex gui-rows gui-align-items-center gui-space-between gui-editor-menus gui-border-box gui-border-t" 	:style="{paddingBottom:ipxHeight}">		<text class="gui-editor-icons gui-icons" data-type="h3"		@tap="graceEditorAddItem" style="font-size:46rpx;"></text>		<text class="gui-editor-icons gui-icons" data-type="txt" 		@tap="graceEditorAddItem" style="font-size:32rpx;"></text>		<text class="gui-editor-icons gui-icons" data-type="center" 		@tap="graceEditorAddItem"></text>		<text class="gui-editor-icons gui-icons" data-type="img" 		@tap="graceEditorAddItem"></text>		<text class="gui-editor-icons gui-icons" data-type="quote" 		@tap="graceEditorAddItem"></text>		<text class="gui-editor-icons gui-icons" data-type="code"		@tap="graceEditorAddItem" style="font-size:40rpx;"></text>		<text class="gui-editor-icons gui-icons" data-type="strong" 		style="font-size:32rpx;" 		@tap="graceEditorAddItem"></text>		<text class="gui-editor-icons gui-icons gui-bold" data-type="link" 		@tap="graceEditorAddItem" style="font-size:38rpx;"></text>		<text class="gui-editor-icons gui-icons gui-bold" data-type="spline" 		@tap="graceEditorAddItem"></text>	</view></view></template><script>export default{	name : "gui-editor",	data() {		return {			article   : { title : '', contents:[] },			ipxHeight : 0		}	},	created:function(){		// #ifdef MP		try {			var system   = uni.getSystemInfoSync();			system.model = system.model.replace(' ', '');			system.model = system.model.toLowerCase();			var res1  = res.model.indexOf('iphonex');			if(res1 > 5){res1 = -1;}			var res2   = res.model.indexOf('iphone1');			if(res2 > 5){res2 = -1;}			if(res1 != -1 || res2 != -1){				this.ipxHeight = '60rpx';			}		} catch (e){return null;}		// #endif	},	methods:{		graceEditorAddItem : function(e){			var type = e.currentTarget.dataset.type;			if(type == 'img'){				uni.chooseImage({					success:(e)=>{						var imgs = e.tempFilePaths;						for(let i = 0; i < imgs.length; i++){							this.article.contents.push({type:type,content:imgs[i], focusin:false});						}					}				});			}else if(type == 'spline'){				this.article.contents.push({type:type,content:'',focusin:false});			}else{				this.article.contents.push({type:type,content:'',focusin:true});			}		},		graceEditorInput : function(e){			var index = e.currentTarget.dataset.index;			var val   = e.detail.value;			this.article.contents[index].content = val;		},		deleteItem : function(e){			var index = e.currentTarget.dataset.index;			uni.showModal({				title:"提示",				content:"确定要删除项目吗?",				success:(e)=>{					if(e.confirm){this.article.contents.splice(index, 1);}				}			})		},		blur    : function (e) {			var index = Number(e.currentTarget.dataset.index);			this.article.contents[index].focusin = false;			this.article.contents.splice(index, 1, this.article.contents[index]);		},		moveup  : function (e) {			var index = Number(e.currentTarget.dataset.index);			if(index > 0){				this.article.contents[index] = this.article.contents.splice(index - 1, 1, this.article.contents[index])[0];			}		},		movedown : function (e) {			var index = Number(e.currentTarget.dataset.index);			if(index < this.article.contents.length - 1){				this.article.contents[index] = this.article.contents.splice(index + 1, 1, this.article.contents[index])[0];			}		},		getData  : function () {			return this.article;		},		setError : function (index) {			this.article.contents[index].error = true;			this.article.contents.splice(index, 1, this.article.contents[index]);		},		setDefault : function (article) {			this.article = article;		}	}}</script><style scoped>.gui-editor{padding:10rpx 25rpx; background-color:#FFFFFF; border-radius:6rpx;}.gui-editor-title{padding:25rpx 0; width:690rpx; font-size:32rpx; line-height:50rpx; color:#2B2E3D;}.gui-editor-empty{line-height:120rpx; font-size:26rpx;}.gui-editor-icons{width:80rpx; height:80rpx; color:#898989; line-height:88rpx; text-align:center; font-size:34rpx; margin:5rpx 0;}.gui-editor-items{margin-top:20rpx;}.gui-editor-item-btns-wrap{padding:20rpx 5rpx;}.gui-editor-item-btns{width:100rpx; border-radius:30rpx; margin-left:20rpx; background-color:#898989;}.gui-editor-item-btns-text{text-align:center; font-size:20rpx; line-height:38rpx; border-radius:30rpx; color:#FFFFFF;}/* #ifndef APP-NVUE */.gui-editor-icons{display:block;}/* #endif */.gui-editor-txt{width:650rpx; font-size:26rpx; line-height:35rpx; padding:20rpx; height:150rpx;}.gui-editor-center{width:500rpx; text-align:center; font-size:28rpx; color:#333333; height:60rpx; line-height:60rpx;}.gui-editor-img-wrap{width:650rpx; height:320rpx; overflow:hidden; position:relative; font-size:0;}.gui-editor-img{width:650rpx; height:320rpx;}.gui-editor-quote{width:650rpx; font-size:26rpx; line-height:35rpx; padding:20rpx; background-color:#F9F9F9; height:100rpx;}.gui-editor-strong{width:650rpx; font-size:26rpx; line-height:35rpx; padding:20rpx; height:100rpx; font-weight:bold;}.gui-editor-link{width:650rpx; font-size:26rpx; line-height:35rpx; padding:20rpx; height:100rpx; color:#008AFF;}.gui-editor-spline{width:650rpx; line-height:60rpx; text-align:center; color:#8788A3; font-size:28rpx; opacity:0.6;}.gui-editor-img-error{position:absolute; width:650rpx; height:320rpx; left:0; top:0; background-color:rgba(0,0,0,0.8);}.gui-editor-img-error-text{font-size:28rpx; color:#FFFFFF;}</style>
 |