2.4-web

冰墩墩心情刻度尺

目标

请在 js/index.js 文件中补全代码,具体需求如下:

不同心情下的冰墩墩对应类名如下表:

心情:类名
不满意.not-satisfied
有点不满意.a-little-unsatisfied
普通.ordinary
满意.satisfied
.great
  1. 在初始状态下,冰墩冰墩元素 (class=BingDunDun) 处于不满意状态。
  2. 进度条在不同位置时,通过给冰墩冰墩元素 (class=BingDunDun) 添加对应类名完成不同心情的效果切切换。
  3. 不能修改原有类名和添加多余类名,例:满意状态下的对应该是 class=BingDunDun satisfied

const range = document.getElementById("range"); // 获取进度条 
const BingDunDun = document.querySelector(".BingDunDun");  //获取冰墩墩元素

// TODO: 待补充代码
let className= "not-satisfied"
BingDunDun.classList.add(className)

range.onchange = (e) => {
  let value = Number(e.target.value); // value 进度条的值
  // TODO: 待补充代码
  BingDunDun.classList.remove(className)
  switch(value){
    case 0:
    className= "not-satisfied"
    break;
    case 25:
    className= "a-little-unsatisfied"
    break;
    case 50:
    className= "ordinary"
    break;
    case 75:
    className= "satisfied"
    break;
    case 100:
    className= "great"
    break;

  }
  BingDunDun.classList.add(className)
};

  1. classList: 这是HTML元素的一个属性,允许你添加、删除、切换和检查元素的类名。
  2. add(className): 这是classList对象的一个方法,用于向当前元素添加一个或多个类名。
  3. className: 这是你想添加到元素的类名。它应该是一个字符串。

 输入搜索联想

目标

请在 index.html 文件中补全代码,最终实现以下需求:

  1. 页面数据表中表头首字母大写(注意:不能是全大写,请勿修改 data 选项中已提供的数据)。
  2. 在搜索输入框中,输入相关单词或字母后(不区分大小写),显示每条数据的 Name 字段中包含该搜索内容的数据列表。
  <body>
    <div id="app">
      <!-- TODO:请在下面实现需求 -->
      <span>搜索名字: </span>
      <input v-model="searchQuery" placeholder="输入要搜索的名字" />
      <table>
        <thead>
          <tr>
            <td v-for="col in columns">{{col.slice(0,1).toUpperCase() + col.slice(1)}}</td>
          </tr>
        </thead>
        <tbody>
          <tr v-for="entry in searchData">
            <td v-for="col in columns">{{entry[col]}}</td>
          </tr>
        </tbody>
      </table>
    </div>
  </body>
</html>
<script>
  // TODO:请在下面实现需求
  new Vue({
    el: "#app",
    // 注意:请勿修改 data 选项中的数据!!!
    data: {
      searchQuery: "",
      columns: ["name", "gender", "age"],
      data: [
        {
          name: "rick",
          gender: "male",
          age: 21,
        },
        {
          name: "demen",
          gender: "male",
          age: 26,
        },
        {
          name: "Jack",
          gender: "male",
          age: 26,
        },
        {
          name: "John",
          gender: "female",
          age: 20,
        },
        {
          name: "Lucy",
          gender: "female",
          age: 16,
        },
      ],
    },
    computed: {
    searchData() {
      return this.data.filter(item => item.name.toLowerCase().includes(this.searchQuery.toLowerCase()))
    }
  }
  });
</script>

通过名为searchData计算属性。

它用于过滤 data 数组,只保留那些其 name 属性包含 searchQuery 的项。让我们逐步分析这段代码:

  1. this.data.filter(...): 这是 JavaScript 的数组方法 filter,它创建一个新数组,包含通过测试的所有元素。
  2. item => ...: 这是一个箭头函数,它接受一个参数 item,代表 data 数组中的每一项。
  3. item.name.toLowerCase(): 这将获取 item 的 name 属性,并将其转换为小写。
  4. this.searchQuery.toLowerCase(): 这将获取 searchQuery 的值,并将其转换为小写。
  5. includes(...): 这是 JavaScript 的字符串方法,用于检查一个字符串是否包含另一个字符串。

因此,整体来说,searchData 方法会遍历 data 数组,对于每一项 item,检查其 name 是否包含 searchQuery(不区分大小写)。如果包含,则将该项添加到新数组中。最后,该方法返回这个新数组。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值