Vue.js实现微信公众号菜单编辑器的代码

南国老符 南国老符 最后更新于:2022-04-18 浏览:1062

创建一个vue实例:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title></title>
    <script src="https://cdn.bootcss.com/vue/2.5.9/vue.js"></script>
</head>
<body>
    <div class="content" style="width:900px;margin:0 auto;">
        <!-- vue实例挂载的DOM元素 -->
        <div id="app-menu">
            <!-- 菜单预览界面 -->
            <div class="weixin-preview"></div>
            <!-- 菜单编辑界面 -->
            <div class="weixin-menu-detail"></div>
        </div>
    </div>
    <script>
        var app = new Vue({
            el: '#app-menu',//挂载到对应的DOM元素
            data: {
                weixinTitle: 'Vue.js公众号菜单',
                //菜单对象
                menu: {
                    "button": [
                        {
                            "name": "主菜单1",
                            "sub_button": []
                        },
                        {
                            "name": "主菜单2",
                            "sub_button": []
                        },
                        {
                            "name": "主菜单3",
                            "sub_button": [
                            {
                                "name": "子菜单1"
                            }]
                        }]
                },
                selectedMenuIndex:'',//当前选中菜单索引
                selectedSubMenuIndex:'',//当前选中子菜单索引
            },
            methods: {
            }
        })
    </script>
</body>
</html>


将菜单数据渲染到模版上
这里使用v-if和v-for将数据渲染到模版上,最多会有3个主菜单以及每个主菜单最多会有5个子菜单。

<div class="weixin-preview">
    <div class="weixin-hd">
        <div class="weixin-title">{{weixinTitle}}</div>
    </div>
    <div class="weixin-bd">
        <ul class="weixin-menu">
            <!-- 这里使用v-for开始循环主菜单 -->
            <li v-for="(btn,i) in menu.button" class="menu-item">
                <div class="menu-item-title">
                    <span>{{ btn.name }}</span>
                </div>
                <ul class="weixin-sub-menu">
                    <!-- 这里使用v-for开始循环主菜单下的子菜单 -->
                    <li v-for="(sub,i2) in btn.sub_button" class="menu-sub-item">
                        <div class="menu-item-title">
                            <span>{{sub.name}}</span>
                        </div>
                    </li>
                    <!-- 这里使用v-if 判断子菜单小于5个,则添加按钮来添加子菜单 -->
                    <li v-if="btn.sub_button.length<5" class="menu-sub-item">
                        <div class="menu-item-title">
                            <i class="icon14_menu_add"></i>
                        </div>
                    </li>
                </ul>
            </li>
            <!-- 这里使用v-if 判断主菜单小于3个,则添加按钮来添加主菜单 -->
            <li class="menu-item" v-if="menu.button.length<3"> <i class="icon14_menu_add"></i></li>
        </ul>
    </div>
</div>


给vue实例添加方法

在vue实例中给methods对象中添加我们自定义的方法

methods: {
    //选中主菜单
    selectedMenu:function (i) {
        this.selectedSubMenuIndex = ''
        this.selectedMenuIndex = i
    },
    //选中子菜单
    selectedSubMenu:function (i) {
        this.selectedSubMenuIndex = i
    },
    //选中菜单级别
    selectedMenuLevel: function () {
        if (this.selectedMenuIndex !== '' && this.selectedSubMenuIndex === '') {
            //主菜单
            return 1;
        } else if (this.selectedMenuIndex !== '' && this.selectedSubMenuIndex !== '') {
            //子菜单
            return 2;
        } else {
            //未选中任何菜单
            return 0;
        }
    },
    //添加菜单 
    //参数level为菜单级别,1为主菜单、2为子菜单
    addMenu:function (level) {
        if (level == 1 && this.menu.button.length < 3) {
            this.menu.button.push({"name": "菜单名称",
                "sub_button": []
            })
            this.selectedMenuIndex = this.menu.button.length - 1
            this.selectedSubMenuIndex = ''
        }
        if (level == 2 && this.menu.button[this.selectedMenuIndex].sub_button.length < 5) {
            this.menu.button[this.selectedMenuIndex].sub_button.push({
                "name": "子菜单名称"
            })
            this.selectedSubMenuIndex = this.menu.button[this.selectedMenuIndex].sub_button.length - 1
        }
    }
}

给菜单绑定方法

当点击菜单触发selectedMenu方法,点击添加按钮触发添加addMenu方法。使用v-on来监听事件,它的缩写是@

监听点击事件@click ,为了防止子菜单点击事件冒泡的主菜单,则使用.stop事件修饰符来阻止冒泡@click.stop

使用v-bind:class来添加切换菜单选中时的class。:class为缩写

<ul class="weixin-menu" id="weixin-menu" >
    <!--  判断如果selectedMenuIndex是当前点击的主菜单索引则添加current样式  -->
    <li v-for="(btn,i) in menu.button" class="menu-item" :class="{current:selectedMenuIndex===i&&selectedMenuLevel()==1}" @click="selectedMenu(i)">
        <div class="menu-item-title">
            <span>{{ btn.name }}</span>
       </div>
        <!--  v-show来切换是否显示 这里如果选中了主菜单则子菜单弹出  -->
        <ul class="weixin-sub-menu" v-show="selectedMenuIndex===i">
            <li v-for="(sub,i2) in btn.sub_button" class="menu-sub-item" :class="{current:selectedSubMenuIndex===i2&&selectedMenuLevel()==2}"  @click.stop="selectedSubMenu(i2)">
                <div class="menu-item-title">
                    <span>{{sub.name}}</span>
                </div>
            </li>
            <li v-if="btn.sub_button.length<5" class="menu-sub-item" @click.stop="addMenu(2)">
                 <div class="menu-item-title">
                        <i class="icon14_menu_add"></i>
                 </div>
            </li>
        </ul>
    </li>
    <li class="menu-item" v-if="menu.button.length<3" @click="addMenu(1)">
        <i class="icon14_menu_add"></i>
    </li>
</ul>


摘自网络,作者github链接:https://github.com/hopex/vue-menu


点赞 (0)

收藏 (0)
转载请务必注明: 来源:《建站管家》https://www.df81.com/news/281.html

本站部分信息来源网络,如有侵权,请联系QQ:1062129401删除。

上一篇: PC端微信扫码支付成功后自动跳转的示例代码

下一篇: 正则匹配6到16位字符组合(且只能为数字、字母、下划线)的PHP代码

请先登录后,再发表评论 ~ ~
发表评论
评论 (0)

发表帖子
广告位招租( ¥5 / 天 )
点击咨询
最新帖子

南国老符
2025-05-26 16:54
南国老符
2024-09-29 10:29
南国老符
2023-12-15 21:41
广告位招租( ¥5 / 天 )
点击咨询
最近评论

U
user1379
回复:版本号多少?
U
user1379
回复:新版本修复了,下载新版本即可
U
user1379
U
user1304
回复:默认没有这个功能,你可以自行二次开发后期可能会考虑在站群版本上加入此功能及商城功能
Y
yuanis90
回复:后台->语言->全局管理->模型管理->编辑->启用关键词内链即可
Y
yuanis90
回复:后台已经启用了,但是前台产品说明的关分键词还是没有自动链接到,
购买VIP
购买授权
余额充值
发表帖子
客服微信