zoukankan      html  css  js  c++  java
  • 85、使用Vue.js实现列表选中效果

      实际项目中,我们会遇到很多类似的需求,一个列表,需要点击其中一条高亮显示。熟悉JQuery的同学说这个太简单了。可以给这个选中的element设置一个active的class。配合Css样式,让active有选中高亮效果。但是谁说一定要用到jQuery呢。

      最近在做的项目中,我尝试脱离JQuery,绕过JQuery,我所接触的大部分项目中好像不使用JQuery无法进行开发一样。它确实给开发者提供了太多便利。以至于大部分web网站都依赖它运行着。据w3Techs统计,JQuery的市场份额高达94.9%,是时候脱离JQuery的束缚了。使用Vue.js更简洁,快速地实现。

      选中效果实现的核心实现逻辑是拷贝一份当前状态作为快照。比对列表的快照和当前的唯一索引,如果相同则视为选中。

    Demo


    图片描述

    使用Vue.js实现


    javascript

    new Vue({
      el: "#app",
      data: {
        gameNames: ['魔兽世界', '暗黑破坏神Ⅲ', '星际争霸Ⅱ', '炉石传说', '风暴英雄',
          '守望先锋'
        ],
        activeName: ''
      },
      methods: {
        selected: function(gameName) {
          this.activeName = gameName
        }
      }
    })

    html

    <div id="app">
      <div class="collection">
        <a href="#!" class="collection-item"
           v-for="gameName in gameNames"
           @click="selected(gameName)"
           :class="{active: activeName == gameName}">{{gameName}}</a>
      </div>
    </div>

    It's done. 非常简洁的代码就实现了选中高亮。View on jsfiddle

     
    参考:https://segmentfault.com/a/1190000005600481
  • 相关阅读:
    Java中Filter、Servlet、Listener的学习 (转)
    Servlet 获取商品信息作业
    Servlet 注册与提交作业
    jsp servlet的区别和联系(转)
    用户注册验证留言程序
    作业1
    简单新闻发布系统
    webform 增速删改查 方法
    存取数据库图片
    打印 保存
  • 原文地址:https://www.cnblogs.com/gfbzs/p/14844368.html
Copyright © 2011-2022 走看看