300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > Vue.js实现微信公众号菜单编辑器步骤详解(下)

Vue.js实现微信公众号菜单编辑器步骤详解(下)

时间:2020-06-27 23:35:36

相关推荐

Vue.js实现微信公众号菜单编辑器步骤详解(下)

web前端|js教程

javascript,Vue.js,编辑器

web前端-js教程实现菜单删除方法

赛马游戏源码,ubuntu屏幕黑掉,tomcat是ejb容器吗,gain 爬虫框架,php动态代理转发,寿宁seolzw

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

类似6房间的聊天源码,vscode到文件首行,ubuntu 12 搜狗,不能运行tomcat服务,创业邦 爬虫,php中验证码不显示,山东专业的seo优化排名报价,音乐小说网站源码,仓储网站模板lzw

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 = \ } } },}

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

传奇微端源码下载,vscode启动程序,ubuntu软件清理,tomcat命名行,sqlite 驱动包,outlook发送服务器端口,快站插件怎么写,后端使用的前端框架,爬虫式算法,php结果是,深圳关键词seo优化公司,免费建手机网站后台,m3u8网页播放源码,员工管理系统模板,jquery 页面路由,web管理系统代码,表白程序代码lzw

{{menu.button[selectedMenuIndex].name}}

删除菜单

检查菜单名称输入长度

用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监听输入事件来检查输入的菜单名长度,长度超出上线则显示提示

菜单名称

字数超过上限

字数不超过4个汉字或8个字母

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

实现选择菜单类型方法

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

先给每个菜单添加下类型

data:{ "menu": { "button": [ { "type": "click", "name": "主菜单1", "key": "测试key", "sub_button": [] }, { "name": "主菜单2", "sub_button": [ { "type": "view", "name": "子菜单", "url": "/v2/guide/" }] }, { "name": "主菜单3", "sub_button": [ { "type": "view", "name": "子菜单", "url": "/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; } }}

菜单内容

跳转网页(view) 发送消息(media_id) 打开指定小程序(miniprogram) 自定义点击事件(click)

用于消息接口推送,不超过128字节

菜单KEY值

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

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

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

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

弹窗组件使用的是layer

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。