虚位以待(AD)
虚位以待(AD)
首页 > 网页特效 > JavaScript > Vue.js 实现微信公众号菜单编辑器功能(二)

Vue.js 实现微信公众号菜单编辑器功能(二)
类别:JavaScript   作者:码皇   来源:互联网   点击:

这篇文章主要介绍了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 = '' }
    }
    }
    ,}

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

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

检查菜单名称输入长度

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

    <div class="weixin-menu-detail"> <div class="menu-input-group"> <div class="menu-label">菜单名称</div> <div 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> </div> </div></div>

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

实现选择菜单类型方法

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

先给每个菜单添加下类型

    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;
    }
    }
    }
    <div class="weixin-menu-detail"> <div class="menu-input-group"> <div class="menu-label">菜单内容</div> <div 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> </div> </div> <!-- 由于内容类型很多,就以click类型为例 --> <div class="menu-content" v-if="selectedMenuType()==3"> <div class="menu-input-group"> <p class="menu-tips">用于消息接口推送,不超过128字节</p> <div class="menu-label">菜单KEY值</div> <div class="menu-input"> <input type="text" class="menu-input-text" v-model="menu.button[selectedMenuIndex].key"> </div> </div> </div></div>

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

  • 数组对象的修改使用Vue的变异方法参考
  • 阻止事件冒泡使用Vue的事件修饰符参考
  • 在切换菜单类型会有一些没有声明属性,但vue初始化实例后不会监听没有声明的属性,所以要使用Vue.set方法来将属性添加到菜单对象上参考

弹窗组件使用的是layer

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

项目地址github

总结

以上所述是小编给大家介绍的Vue.js 实现微信公众号菜单编辑器功能(二),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

您可能感兴趣的文章:

  • Vue.js 实现微信公众号菜单编辑器功能(一)
  • 巧用Vue.js+Vuex制作专门收藏微信公众号的app
  • Vue.js结合Ueditor富文本编辑器的实例代码
相关热词搜索: vue js 微信公众号菜单编辑器 vue js 微信