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
    评论
在HTML中使用Vue.js实现九宫格抽奖功能,首先你需要了解HTML(HyperText Markup Language)用于创建网页结构,Vue.js(一个流行的前端JavaScript框架)则提供了数据绑定和组件化的开发能力。以下是一个简单的步骤指南: 1. **设置项目结构**: 创建一个新的Vue项目,你可以使用Vue CLI工具快速初始化。 ```bash vue create my-kongguo-draw cd my-kongguo-draw ``` 2. **安装所需依赖**: 在`src`目录下,安装`vue-grid-layout`库,它可以帮助你轻松地创建网格布局。 ```bash npm install vue-grid-layout --save ``` 3. **创建组件**: - `KongGuoDraw.vue`:这是主要的组件,负责渲染九宫格并处理抽奖逻辑。 ```html <template> <div class="kong-guo-draw"> <vue-grid-layout :layout="gridLayout" @draw="onDraw"> <!-- 使用v-for遍历每个网格单元 --> <div v-for="(item, index) in gridItems" :key="index" :style="{ top: item.y, left: item.x }"> <button @click="onCellClick(index)">点击抽奖</button> </div> </vue-grid-layout> </div> </template> <script> import Vue from 'vue'; import vueGridLayout from 'vue-grid-layout'; export default { components: { vueGridLayout, }, data() { return { gridLayout: { // 初始化的网格布局配置 }, gridItems: [], // 九宫格的元素数组 }; }, methods: { onDraw() { // 在这里编写抽奖逻辑 }, onCellClick(index) { // 当点击某个单元格时触发 this.gridItems[index].isDrawn = true; // 标记已抽奖 }, }, }; </script> ``` 4. **定义九宫格布局**: 在`data`中,根据九宫格的需求配置`gridLayout`和`gridItems`。九宫格通常是3x3的布局,你可以设置列数、行数和每个单元格的大小。 5. **实现抽奖逻辑**: 在`onDraw`方法中,可以根据需求决定如何选择或改变九宫格中的奖项。可能的方式包括随机选择一个单元格或者当所有单元格都被点击后选择一个。 6. **添加样式**: 在`<style>`标签内,为九宫格和按钮添加合适的CSS样式。 记得在`main.js`中导入并使用这个组件,这样九宫格抽奖功能就完成了。以上代码只是一个基础示例,实际应用中可能需要根据具体需求调整和优化。如果你有任何问题,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值