《vue3实战》通过indexOf方法实现电影评价系统的模糊查询功能

简介: 《vue3实战》通过indexOf方法实现电影评价系统的模糊查询功能

前言

电影评价系统的模糊查询是什么?它的作用体现在哪些方面?

电影评价系统的模糊查询是一种查询方法,用于在用户输入的关键词中进行模糊匹配,而不仅仅是精确匹配。这种查询方法可以查找到与关键词相关的结果,即使关键词的拼写或格式有所不同。

模糊查询的作用体现在以下方面:

  1. 提高用户体验:模糊查询可以更好地满足用户的搜索需求,即使用户输入的关键词存在一定的拼写错误或格式差异,也能够找到相关的结果。这样可以提高用户对系统的满意度,并减少他们需要进行多次尝试的次数。
  2. 扩展搜索结果:模糊查询可以使系统返回更全面的搜索结果。通常来说,精确匹配可能会忽略一部分相关的内容,而模糊查询可以找到更多满足用户要求的结果,包括拼写相似或格式近似的内容。
  3. 对应多样性需求:不同用户对于搜索结果的要求可能存在一定的差异。一些用户可能更关注特定类型的电影,而另一些用户可能更注重演员、导演等相关信息。通过模糊查询,系统能够根据用户输入的关键词,提供更加符合他们需求的搜索结果。
  4. 灵活匹配多种场景:在电影评价系统中,用户可能输入的关键词包括电影名称、演员、导演、电影类型等。模糊查询可以在这些不同的场景下,根据用户输入的关键词进行模糊匹配,找到与之相关的电影评价。

一、indexOf是什么?indexOf有什么作用?

含义:

indexOf是一个JavaScript数组的方法,用于在数组中查找指定元素的索引。

作用:
  1. 查找元素:indexOf可以用来判断数组中是否存在某个元素。如果指定元素存在于数组中,则返回第一次出现的索引;如果不存在,则返回-1。
  2. 根据索引操作数组:知道元素在数组中的索引,我们可以使用这个索引来访问、修改和删除数组中的元素。
  3. 判断元素是否唯一:由于indexOf只返回第一次出现的索引,可以通过它来判断一个元素在数组中是否是唯一的。

二、功能实现

这段是查询过程中过滤筛选功能的代码部分:

分析:

  1. 如果this.userForm.userName不为空且this.userForm.sex不为空:
  • 通过user.username.indexOf(this.userForm.userName) >= 0判断用户的用户名是否包含了this.userForm.userName,如果是则返回true,否则返回false。
  • 通过user.sex.indexOf(this.userForm.sex) >= 0判断用户的性别是否包含了this.userForm.sex,如果是则返回true,否则返回false。
  • 只有当用户名和性别都满足条件时,才返回true。
  1. 如果this.userForm.userName不为空且this.userForm.sex为空:
  • 通过user.username.indexOf(this.userForm.userName) >= 0判断用户的用户名是否包含了this.userForm.userName,如果是则返回true,否则返回false。
  • 只有当用户名满足条件时,才返回true。
  1. 如果this.userForm.userName为空且this.userForm.sex不为空:
  • 通过user.sex.indexOf(this.userForm.sex) >= 0判断用户的性别是否包含了this.userForm.sex,如果是则返回true,否则返回false。
  • 只有当性别满足条件时,才返回true。
  1. 如果this.userForm.userName为空且this.userForm.sex为空:
  • 直接返回true,表示不对用户名和性别进行筛选。

          因此,这段代码的功能是根据用户输入的条件对用户进行筛选,可以根据用户名和性别分别进行筛选,也可以只根据其中一个条件进行筛选,同时也支持不设定任何筛选条件。

这段是查询用户和性别功能的代码部分:

         

分析:

  1. 通过this.courses.filter(this.filterRule)使用filterRule函数对this.courses数组进行筛选,得到符合条件的用户数据,并赋值给this.newCourses数组。
  2. 通过this.newCourses.length获取this.newCourses数组的长度,即符合条件的用户数量,并将其赋值给this.total变量。
  3. 根据用户输入的分页参数,计算出当前页显示的用户数据的起始索引和结束索引,并赋值给startend变量。
  4. 通过this.newCourses.slice(start, end)startend为范围,获取this.newCourses数组中对应范围的用户数据,并将其赋值给this.pageMess变量。

       因此,这段代码的功能是根据用户输入的筛选条件,对this.courses数组中的用户数据进行筛选,并根据分页参数获取对应页码的用户数据,最终将符合条件的用户数据赋值给this.pageMess变量,并更新this.total变量以反映符合条件的用户总数量。

三、最终效果图

查询输入框所在图:

输入姓名羊和性别男模糊查询后的效果图:

输入姓名羊和性别女模糊查询后的效果图:

单独输入姓名狼模糊查询后的效果图:

四、代码块

 <div style="margin-left: 150px;margin-top: 0px">
                  <span><input type="text" placeholder="请输入姓名" v-model="userForm.userName"></span>
                  <span><input type="text" placeholder="请输入性别" v-model="userForm.sex"></span>
                  <button @click="queryUser()"
                          style="background-color: #1989fa;border-radius:5px;width:60px;height:30px">
                    查询
                  </button>
</div>
 
  mounted() {
 
    this.$watch('userForm.page.userPage', function () {
      if (this.userForm.userName == "" && this.userForm.sex == "") {
        if (this.userForm.page.userPage > Math.ceil(this.courses.length / this.userForm.page.pageSize) || this.userForm.page.userPage < 0) {
          this.userForm.page.userPage = 1;
        }
        let start = (this.userForm.page.userPage - 1) * this.userForm.page.pageSize;
        let end = (this.userForm.page.userPage * this.userForm.page.pageSize);
        this.pageMess = this.courses.slice(start, end);
      } else if (this.userForm.userName != "" && this.userForm.sex == "") {
        if (this.userForm.page.userPage > Math.ceil(this.newCourses.length / this.userForm.page.pageSize) || this.userForm.page.userPage < 0) {
          this.userForm.page.userPage = 1;
        }
        let start = (this.userForm.page.userPage - 1) * this.userForm.page.pageSize;
        let end = (this.userForm.page.userPage * this.userForm.page.pageSize);
        this.pageMess = this.newCourses.slice(start, end);
      } else if (this.userForm.userName == "" && this.userForm.sex != "") {
        if (this.userForm.page.userPage > Math.ceil(this.newCourses.length / this.userForm.page.pageSize) || this.userForm.page.userPage < 0) {
          this.userForm.page.userPage = 1;
 
        }
        let start = (this.userForm.page.userPage - 1) * this.userForm.page.pageSize;
        let end = (this.userForm.page.userPage * this.userForm.page.pageSize);
        this.pageMess = this.newCourses.slice(start, end);
      } else if (this.userForm.userName != "" && this.userForm.sex != "") {
        if (this.userForm.page.userPage > Math.ceil(this.newCourses.length / this.userForm.page.pageSize) || this.userForm.page.userPage < 0) {
          this.userForm.page.userPage = 1;
        }
        // let start = (this.userForm.page.userPage - 1) * this.userForm.page.pageSize;
        // let end = (this.userForm.page.userPage * this.userForm.page.pageSize);
        // this.pageMess = this.newCourses.slice(start, end);
        let start = (this.userForm.page.userPage - 1) * this.userForm.page.pageSize;
        let end = (this.userForm.page.userPage * this.userForm.page.pageSize);
        this.pageMess = this.newCourses.slice(start, end);
      }
    })
  },
  methods: {
    filterRule(user) {
      if (!(!this.userForm.userName) && this.userForm.sex != "") {
        return user.username.indexOf(this.userForm.userName) >= 0
            && user.sex.indexOf(this.userForm.sex) >= 0;
      } else if (!(!this.userForm.userName) && this.userForm.sex.length == 0) {
        return user.username.indexOf(this.userForm.userName) >= 0
      } else if (this.userForm.userName.length == 0 && !(!this.userForm.sex)) {
        return user.sex.indexOf(this.userForm.sex) >= 0
      } else {
        return true
      }
    },
    queryUser() {
      // this.newCourses = this.courses.filter(this.filterRule)
      this.newCourses = this.courses.filter(this.filterRule)
      this.total = this.newCourses.length
      // debugger
      let start = (this.userForm.page.userPage - 1) * this.userForm.page.pageSize;
      let end = (this.userForm.page.userPage * this.userForm.page.pageSize);
      this.pageMess = this.newCourses.slice(start, end);//[0,5)
    },


总结

       总的来说,模糊查询可以提高用户搜索的准确性和满意度,并增加搜索结果的完整性和多样性。它能够更好地满足用户在电影评价系统中的搜索需求。

      总之,indexOf是一个用于查找数组中指定元素索引的方法,可以方便地对数组进行操作和判断。

相关文章
|
6月前
|
前端开发
React查询、搜索类功能的实现
React查询、搜索类功能的实现
63 0
|
缓存 前端开发 JavaScript
React Table 表格组件使用教程 排序、分页、搜索过滤筛选功能实战开发
在日常开发中,特别是内部使用的后台系统时,我们常常会需要用表格来展示数据,同时提供一些操作用于操作表格内的数据。简单的表格直接用原生 HTML table 就好,但如果要在 React 中实现一个功能丰富的表格,其实是非常不容易的。在本站之前的文章《最好的 6 个 React Table 组件详细亲测推荐》 中有提到过 react-table 这个库,如果对这个库不太了解的同学可以先了解一下,这里不再赘述。简而言之,react-table 是一个非常强大的库,它与常见的表格组件不同,它不负责渲染 HTML 和 CSS,而是提供了一系列的 hooks 让我们可以灵活地构建功能强大的表格组件。
1328 0
|
JavaScript 前端开发 定位技术
|
3月前
|
资源调度 JavaScript 定位技术
Vue2使用百度地图展示或搜索地点(vue-baidu-map)
本文介绍了如何在 Vue 项目中使用 `vue-baidu-map` 插件,包括安装、全局注册及具体应用。首先通过 `yarn add vue-baidu-map` 安装插件,并在 `main.js` 中全局注册。然后展示了如何在地图上显示特定位置的标记,以及如何搜索地点并获取其经纬度和详细地址信息。代码示例提供了详细的实现方法和样式调整。如需使用,请确保已获取百度地图 API 的密钥。
534 1
|
11月前
|
JSON 小程序 JavaScript
|
6月前
|
搜索推荐 算法 Java
电影推荐|基于SSM+vue的电影推荐系统的设计与实现(源码+数据库+文档)
电影推荐|基于SSM+vue的电影推荐系统的设计与实现(源码+数据库+文档)
131 3
|
6月前
|
JavaScript Java 测试技术
基于ssm+vue.js的四六级报名与成绩查询系统附带文章和源代码设计说明文档ppt
基于ssm+vue.js的四六级报名与成绩查询系统附带文章和源代码设计说明文档ppt
45 0
|
6月前
|
搜索推荐 JavaScript 前端开发
《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能
《vue3实战》运用splice方法实现电影评价系统的查看、修改、删除功能
|
6月前
|
搜索推荐 JavaScript 前端开发
《vue3实战》运用push()方法实现电影评价系统的添加功能
《vue3实战》运用push()方法实现电影评价系统的添加功能
《vue3实战》运用push()方法实现电影评价系统的添加功能
|
6月前
|
JavaScript
Vue实现模糊查询搜索功能
Vue实现模糊查询搜索功能
115 0