VUE+ElementUI模式下,实现菜单的显示与隐藏

     最近这个需求是,由于查询条件太多,想将一部分查询条件先隐藏起来,需要时再点击显示按钮进行展示。

我们的前端环境是vue+ElementUI的,查阅了官网案例http://element-cn.eleme.io/#/zh-CN/component/collapse

只找到了Collapse 折叠面板,由于里面一些组件是写死的,不能进行个性化修改,所以不能满足现在的需求,只能放弃!

我们主要想实现的功能就是,如下图:

点击收起后:

就是这么一个简单的功能,在vue+Element的环境下,实现起来有些困难,因为一些原生的js用不了。。。。

最后还是利用了最原始的思路,隐藏和展示div的思想,html代码如下,将要隐藏的内容放在一个div中:


<div id="showOrHide" style="margin-bottom: 0px">
                    <el-row>
                        <el-col :span="24">
                            <el-form-item prop="code">
                                <el-input v-model="queryForm.code" placeholder="编码"></el-input>
                            </el-form-item>

                            <el-form-item prop="agent">
                                <el-input v-model="queryForm.agent" placeholder="代理商"></el-input>
                            </el-form-item>
                            <el-form-item prop="pattern">
                                <el-input v-model="queryForm.pattern" placeholder="模式"></el-input>
                            </el-form-item>
                        
                        </el-col>
                    </el-row>
                  
                </div>
<!--给按钮绑定点击事件-->
                <el-button @click="showOrHide()"
                           style="border-color:white;background-color:white;font-size: x-small;color:#50bfff;padding:1px 2px;margin-left: 40%;margin-top: 0px;margin-bottom: 15px"
                           :icon="icon">{{showOrHideText}}
                </el-button>

js代码如下:

$(function () {
//控制隐藏和展示的按钮
    $("#showOrHide").hide();
//原vue中的大DIV
var business = new Vue({
        el: '#business',
        data: {
           
//按钮上的展示文字
            showOrHideText: "显示更多查询条件",
            buttonBoolean: false,
//图标,可根据自己的需求匹配
            icon: 'el-icon-caret-bottom'},
....此处省略无关代码。。。
 methods: {
//隐藏和展示的控制方法
showOrHide: function () {
                if (business.buttonBoolean) {
                    business.icon = 'el-icon-caret-bottom';
                    business.showOrHideText = "显示更多查询条件";
                    $("#showOrHide").hide();

                    business.buttonBoolean = !business.buttonBoolean;
                } else {
                    $("#showOrHide").show();
                    business.icon = 'el-icon-caret-top';
                    business.showOrHideText = "收起";
                    business.buttonBoolean = !business.buttonBoolean;
                }
            },
}
})
})

以上,就能够实现了,思路上和我们的之前的js是一样的,只是在vue和Element的环境下,一些元素的获取和绑定方式不太一样,希望能给需要的朋友提供帮助!

如果有更好的方法,欢迎大家留言告知,谢谢!

  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值