vue.js-动态绑定class 利用index实现导航

 1 <template>
 2     <div class="stock">
 3         <div class="buin_leftcont nav_ctrl">
 4             <ul class="buin_leftnav">
 5                 <template  v-for="(item, index) in menu_list">
 6                     <router-link :to="item.urls">
 7                         <li @click="show_ctrl(index)" :class="{'active':index===isActive}">
 8                             <span>{{item.name}}</span>
 9                         </li>
10                     </router-link>
11                 </template>
12             </ul>
13         </div>
14         <div class='stock_router'>
15             <router-view></router-view>
16         </div>
17     </div>
18 </template>
19 
20 <script>
21     import  $ from 'jquery'
22     export default {
23         name: 'stock',
24         data () {
25             return {
26                 isActive:'',
27                 menu_list:[
28                     {name:'阀门管理',urls:'/Stock/Fm_manage', show: false},
29                     {name:'工具管理',urls:'/Stock/Fm_manage', show: false},
30                     {name:'执行器管理',urls:'/Stock/Fm_manage', show: false},
31                     {name:'研磨设备管理',urls:'/Stock/Fm_manage', show: false},
32                     {name:'加工设备管理',urls:'/Stock/Fm_manage', show: false},
33                     {name:'检测设备管理',urls:'/Stock/Fm_manage', show: false},
34                     {name:'人才信息管理',urls:'/Stock/Fm_manage', show: false},
35                 ]
36             }
37         },
38         mounted(){
39         },
40         methods:{
41             show_ctrl(index){
42                 this.isActive=index;
43             }
44         }
45     }
46 </script>
47 
48 <!-- Add "scoped" attribute to limit CSS to this component only -->
49 <style scoped>
50     .stock{
51         display: flex;
52     }
53     .buin_leftnav{
54         display: flex;
55         flex-direction:column;
56         width: 246px;
57         margin-top: 10px;
58         margin-left: 10px;
59     }
60     .stock_router{
61         width: 90%;
62         flex-grow:2
63     }
64     .nav_ctrl ul{
65         background:#1999D7;
66         width:200px;
67     }
68 
69     .nav_ctrl li{
70         height:30px;
71         line-height:30px;
72         vertical-align:middle;
73         padding:10px 10px;
74         color:#FFF;
75         font-family:"微软雅黑","幼圆",Arial, sans-serif;
76         font-size:20px;
77         font-weight:500;
78         text-align:center;
79         cursor:pointer;
80         -webkit-transition: all 0.4s ease-in-out;
81         -moz-transition: all 0.4s ease-in-out;
82         -o-transition: all 0.4s ease-in-out;
83     }
84 
85     .nav_ctrl li:hover{
86         background:#FF9000;
87         -webkit-transform:scale(1.1);
88         -moz-transform:scale(1.1);
89         -o-transform:scale(1.1);
90     }
91     .active{
92         background:#FF9000;
93         /*-webkit-transform:scale(1.1);*/
94         /*-moz-transform:scale(1.1);*/
95         /*-o-transform:scale(1.1);*/
96     }
97 </style>

关键部分的截图

 

转载于:https://www.cnblogs.com/xiaomili/p/6569225.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue动态绑定v-model,有几种方法可以实现。其中一种方法是使用一个数组来存储动态生成的input的值,并使用v-model绑定到数组的每个元素上。 首先,创建一个空的数组,比如selectVal: []。然后,使用v-model绑定到每个input上,如v-model="selectVal[index].value"。接下来,使用循环或其他方式动态生成需要绑定v-model的input的数量,比如使用for循环生成10个input。 示例代码如下: ``` data() { return { selectVal: [] // 创建一个空的数组 } }, mounted() { var len = 10; for (var i = 0; i < len; i++) { var item = { value: '' }; // 创建一个对象,用来存储input的值 this.selectVal.push(item); // 将对象添加到数组中 } } ``` 在上述代码中,通过循环生成了10个需要绑定v-model的input,将每个input的值存储在selectVal数组中的对应元素的value属性中。 通过这种方式,可以实现动态绑定v-model,并且根据接口返回的数据动态生成相应数量的input。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [在 vue.js动态绑定 v-model](https://blog.csdn.net/qq_30944053/article/details/88634779)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [vue v-model动态生成详解](https://download.csdn.net/download/weixin_38696336/14904156)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值