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

知识技术 2022-04-18 12:20 876
转载请务必注明: 来源:《建站管家》https://www.df81.com/news/281.html

创建一个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)

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

上一篇: 《建站管家》二次开发文档

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

请先登录后,再发表评论 ~ ~
发表评论
发表评论
发表帖子
广告位招租( ¥5 / 天 )
点击咨询
相关帖子

如果要判断文件是否存在,用函数 is_file(),如果要判断目录是否存在,用函数 is_dir()
用宝塔安装TP程序后,网站前台可以访问,后台无法访问,不是程序问题,而是web服务器环境配置问题(PHP配置),出现这种问题,一般是windows主机安装宝塔造成的,linux安装宝塔不会出现此错误
广告位招租( ¥3 / 天 )
点击咨询
广告位招租( ¥2 / 天 )
点击咨询
广告位招租( ¥1 / 天 )
点击咨询
最新帖子

小朋友,你爸爸是谁啊?这很单纯的,就像我们碰到别人会问:你吃过饭了吗?类似;许多人初次相识,经常会问:你是做什么的啊?你做什么,好像决定你收入的高低,你,资产的范围
1、升级框架到ThinkPHP8.0.3【要求PHP8.1+环境,推荐PHP8.1】 2、启用/禁用调试模式等小细节改进
后台点击生成站点地图 一直转圈圈没有反应,
在线客服