公众号 菜单 代码 php,如何使用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(/[^\x00-\xff]/ig) != null?len += 2:len += 1;

}

return len;

}

}

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

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

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

9ec495e1491019c00116b2f0962d9d51.gif

实现选择菜单类型方法

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

先给每个菜单添加下类型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;

}

}

}

跳转网页(view)

发送消息(media_id)

打开指定小程序(miniprogram)

自定义点击事件(click)

0e9d8994d82b5ce619c3e2f495ab7a6f.gif

菜单的添加、编辑、删除功能基本完成了,总结一下学习到的知识数组对象的修改使用Vue的变异方法参考

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

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

弹窗组件使用的是layer

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

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

推荐阅读:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值