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

这次给大家带来如何使用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 = ''   }  } },}

登录后复制

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

登录后复制

检查菜单名称输入长度

用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(/[^-�]/ig) != null?len += 2:len += 1;  }  return len; }}

登录后复制

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

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

登录后复制

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

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

实现选择菜单类型方法

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

先给每个菜单添加下类型

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;  } }}

登录后复制

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

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

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

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

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

弹窗组件使用的是layer

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

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

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

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

以上就是如何使用Vue.js实现微信公众号菜单编辑器(案例代码)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2753258.html

(0)
上一篇 2025年3月8日 06:35:28
下一篇 2025年3月6日 23:02:26

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论