最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

如何使用Vue.js实现微信公众号菜单编辑器(案例代码)

来源:动视网 责编:小采 时间:2020-11-27 19:43:33
文档

如何使用Vue.js实现微信公众号菜单编辑器(案例代码)

如何使用Vue.js实现微信公众号菜单编辑器(案例代码):这次给大家带来如何使用Vue.js实现微信公众号菜单编辑器(案例代码),使用Vue.js实现微信公众号菜单编辑器的注意事项有哪些,下面就是实战案例,一起来看一下。实现菜单删除方法在vue实例中添加删除菜单方法,根据选中的菜单级别和索引来删除。method
推荐度:
导读如何使用Vue.js实现微信公众号菜单编辑器(案例代码):这次给大家带来如何使用Vue.js实现微信公众号菜单编辑器(案例代码),使用Vue.js实现微信公众号菜单编辑器的注意事项有哪些,下面就是实战案例,一起来看一下。实现菜单删除方法在vue实例中添加删除菜单方法,根据选中的菜单级别和索引来删除。method
 这次给大家带来如何使用Vue.js实现微信公众号菜单编辑器(案例代码),使用Vue.js实现微信公众号菜单编辑器的注意事项有哪些,下面就是实战案例,一起来看一下。

实现菜单删除方法

在vue实例中添加删除菜单方法,根据选中的菜单级别和索引来删除。

methods: {
 //删除菜单
 delMenu:function(){
 //删除主菜单
 if(this.selectedMenuLevel()==1&&confirm('删除后菜单下设置的子菜单也将被删除')){
 if(this.selectedMenuIndex===0){
 this.menu.button.splice(this.selectedMenuIndex, 1);
 this.selectedMenuIndex = 0;
 }else{
 this.menu.button.splice(this.selectedMenuIndex, 1);
 this.selectedMenuIndex -=1;
 }
 if(this.menu.button.length==0){
 this.selectedMenuIndex = ''
 }
 //删除子菜单
 }else if(this.selectedMenuLevel()==2){
 if(this.selectedSubMenuIndex===0){
 this.menu.button[this.selectedMenuIndex].sub_button.splice(this.selectedSubMenuIndex, 1);
 this.selectedSubMenuIndex = 0;
 }else{
 this.menu.button[this.selectedMenuIndex].sub_button.splice(this.selectedSubMenuIndex, 1);
 this.selectedSubMenuIndex -= 1;
 }
 if(this.menu.button[this.selectedMenuIndex].sub_button.length==0){
 this.selectedSubMenuIndex = ''
 }
 }
 },
}

将方法绑定了菜单编辑界面

<p class="weixin-menu-detail">
 <!-- 显示选中的菜单和删除菜单按钮 -->
 <p class="menu-input-group" style="border-bottom: 2px #e8e8e8 solid;">
 <p class="menu-name">{{menu.button[selectedMenuIndex].name}}</p>
 <p class="menu-del" @click="delMenu">删除菜单</p>
 </p>
 </p>
 </p>

检查菜单名称输入长度

用v-model指令在输入框绑定菜单名,@input监听输入事件来检查输入的菜单名长度,超出上限则显示提示

data:{
 menuNameBounds:false,//菜单长度超出上限标记
},
methods:{
 //判断菜单名长度
 checkMenuName:function(val){
 if(this.selectedMenuLevel()==1&&this.getMenuNameLen(val)<=8){
 this.menuNameBounds=false
 }else if(this.selectedMenuLevel()==2&&this.getMenuNameLen(val)<=16){
 this.menuNameBounds=false
 }else{
 this.menuNameBounds=true
 }
 },
 //获取字符串中文字符长度
 getMenuNameLen: function (val) {
 var len = 0;
 for (var i = 0; i < val.length; i++) {
 var a = val.charAt(i);
 a.match(/[^\x00-\xff]/ig) != null?len += 2:len += 1;
 }
 return len;
 }
}

添加菜单编辑界面和事件监听

v-model指令用来绑定菜单名输入框的值,@input监听输入事件来检查输入的菜单名长度,长度超出上线则显示提示

<p class="weixin-menu-detail">
 <p class="menu-input-group">
 <p class="menu-label">菜单名称</p>
 <p class="menu-input">
 <input type="text" name="name" placeholder="请输入菜单名称" class="menu-input-text" v-model="menu.button[selectedMenuIndex].name" @input="checkMenuName(menu.button[selectedMenuIndex].name)">
 <!-- 这里用v-show来判断是否超过上限,menuNameBounds为true则显示 -->
 <p class="menu-tips" style="color:#e15f63" v-show="menuNameBounds">字数超过上限</p>
 <p class="menu-tips">字数不超过4个汉字或8个字母</p>
 </p>
 </p>
</p>

截图工具不显示删除的弹框,将就一下吧...

实现选择菜单类型方法

微信菜单有多种类型所以需要做个下拉列表,选中下拉项后显示该项的内容

先给每个菜单添加下类型

data:{
 "menu": {
 "button": [
 {
 "type": "click",
 "name": "主菜单1",
 "key": "测试key",
 "sub_button": []
 },
 {
 "name": "主菜单2",
 "sub_button": [
 {
 "type": "view",
 "name": "子菜单",
 "url": "https://cn.vuejs.org/v2/guide/"
 }]
 },
 {
 "name": "主菜单3",
 "sub_button": [
 {
 "type": "view",
 "name": "子菜单",
 "url": "https://cn.vuejs.org/v2/guide/"
 }
 }]
 }
}

创建的下拉列表也使用v-model指令来绑定选中的菜单类型

//获取菜单类型 1. view网页类型,2. media_id类型和view_limited类型 3. click点击类型,4.miniprogram表示小程序类型
methods: {
 selectedMenuType: function () {
 switch (this.menu.button[this.selectedMenuIndex].type) {
 case 'view':return 1;
 case 'media_id':return 2;
 case 'click':return 3;
 case 'miniprogram':return 4;
 }
 }
}
<p class="weixin-menu-detail">
 <p class="menu-input-group">
 <p class="menu-label">菜单内容</p>
 <p class="menu-input">
 <select v-model="menu.button[selectedMenuIndex].type" name="type" class="menu-input-text">
 <option value="view">跳转网页(view)</option>
 <option value="media_id">发送消息(media_id)</option>
 <option value="miniprogram">打开指定小程序(miniprogram)</option>
 <option value="click">自定义点击事件(click)</option>
 </select>
 </p>
 </p>
 <!-- 由于内容类型很多,就以click类型为例 -->
 <p class="menu-content" v-if="selectedMenuType()==3">
 <p class="menu-input-group">
 <p class="menu-tips">用于消息接口推送,不超过128字节</p>
 <p class="menu-label">菜单KEY值</p>
 <p class="menu-input">
 <input type="text" class="menu-input-text" v-model="menu.button[selectedMenuIndex].key">
 </p>
 </p>
 </p>
</p>

菜单的添加、编辑、删除功能基本完成了,总结一下学习到的知识

  • 数组对象的修改使用Vue的变异方法参考

  • 阻止事件冒泡使用Vue的事件修饰符参考

  • 在切换菜单类型会有一些没有声明属性,但vue初始化实例后不会监听没有声明的属性,所以要使用Vue.set方法来将属性添加到菜单对象上参考

  • 弹窗组件使用的是layer

    素材列表使用的模版是art-template

    相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

    推荐阅读:

    如何使用Vue.js实现微信公众号菜单编辑器(思路详解)

    怎样使用JS实现计算圆周率到小数点后100位

    文档

    如何使用Vue.js实现微信公众号菜单编辑器(案例代码)

    如何使用Vue.js实现微信公众号菜单编辑器(案例代码):这次给大家带来如何使用Vue.js实现微信公众号菜单编辑器(案例代码),使用Vue.js实现微信公众号菜单编辑器的注意事项有哪些,下面就是实战案例,一起来看一下。实现菜单删除方法在vue实例中添加删除菜单方法,根据选中的菜单级别和索引来删除。method
    推荐度:
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top