Vue实现搜索结果高亮显示关键字


Posted in Javascript onMay 28, 2019

本文实例为大家分享了Vue实现搜索结果高亮显示关键字的具体代码,供大家参考,具体内容如下

1. 需要解决的问题

  • 父组件将搜索的字段传到子组件
  • 子组件接受数据,正则匹配,并替换字段

2. 具体代码

父组件代码

<template>
 <div>
 <div v-if="showMe">
 <div class="re_search">
  <svg @click="$router.go(-1)">
  <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#arrow-left.6f6409e" rel="external nofollow" ></use>
  </svg>
  <input type="search" v-model="search_text" class="v-md" placeholder="请输入商品名称" @keydown.enter="search_method">
 </div>
 <OneBusiness v-for="(item, n) in search_res" :key="n" :item="item" :search_text="search_text"></OneBusiness>
 </div>
 <!--<!– 撑开Fixednav挡住的位置 –>-->
 <div class="space"></div>
 <!-- 固定导航栏 -->
 </div>
</template>

<script>
import { mapGetters } from 'vuex';
import OneBusiness from './small_components/One_business';
import {getSearchData} from 'src/service/getData'


export default {
 name: 'search',
 data () {
 return {
  showMe: false,
  search_text: '', // 搜索框内容
  search_res: [] // 搜索结果
 };
 },
 mounted () {
 this.$store.dispatch('setLoading', true);
 // 模拟加载
 var time = Math.floor(Math.random() * 2000);
 console.log('模拟加载用时' + time);
 setTimeout(() => {
  this.$store.dispatch('setLoading', false);
  this.showMe = true;
 }, time);
 this.search_method();
 },
 computed: {
 ...mapGetters([
  'getFalseBussinessbrief' // 商家简略信息
 ])
 },
 methods: {
 async search_method () {

  var mainWord = this.$route.params.keyword;
  if (this.search_text !== '' && this.search_text !== this.$route.params.keyword) {
  mainWord = this.search_text;
  }
  this.search_text = mainWord;
  this.search_res = (await getSearchData(this.search_text)).obj.results;
  console.log(this.search_res);
 }
 },
 components: {
 OneBusiness
 }
};
</script>

<style lang="less" scoped>
.re_search{
 background:#0096ff;
 line-height:0;
 padding: .2rem;
 svg{
 width:.6rem;
 height:.6rem;
 }
 input[type="search"]{
 display:inline-block;
 height:.9rem;
 width:8rem;
 outline: none;
 border: none;
 border-radius:.45rem;
 background:#f2f2f2;
 box-sizing: border-box;
 padding: 0 .5rem;
 font-size:.4rem;
 }
}
</style>

子组件代码

<template>
 <!-- 列表单个商家 -->
 <section class="tj_business" >
 <section class="one_business clear">
  <div class="business_img">
  <img src="../../images/guozhao.png" alt="">
  </div>
  <div class="business_info">
  <section class="business_name clear">
   <router-link :to="'/business/' + item.classNum">
   <h3 class="fl ell"><span v-if="item.className">大类</span>第{{item.classNum}}类{{ item.className }}</h3>
   </router-link>
   <div class="name_icon fr">
   <div class="code_num fr">
    <svg @click="add_cart(item.id)" style=" width: .5rem; height: .5rem;">
    <use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#cart-minus" rel="external nofollow" ></use>
    </svg>
   </div>
   </div>
  </section>
  <section class="business_code clear">
   <div class="code_num fl">
   <!--<svg class="v-md">-->
    <!--<use xmlns:xlink="http://www.w3.org/1999/xlink" xlink:href="#rating-star" rel="external nofollow" ></use>-->
   <!--</svg>-->
   <span class="v-md">【{{item.parentNum}}组】{{ item.groupName }}</span>
   </div>
   <div class="code_icon fr">
   </div>
  </section>
  <section class="business_other clear">
   <div class="other_price fl">
   <span class="com_gray1" v-html="ruleTitle"></span>
   <span>/</span>
   <span class="com_gray1">{{ item.number }}</span>
   </div>
   <div class="other_dis fr">
   </div>
  </section>
  </div>
 </section>

 </section>

</template>

<script>
 import {
 addMyshopcart,
 } from 'src/service/getData'

 export default {
 name: 'one_business',
 props: {
  search_text:String,
  item:{}
 },
 data () {
  return {
  msg: '1'

  };
 },
 mounted () {

 },
 computed: {
  isLogin () {
  return this.$store.getters.getLogin;
  },
  ruleTitle() {
  let titleString = this.item.gname;
  if (!titleString) {
   return '';
  }
  if (this.search_text && this.search_text.length > 0) {
   // 匹配关键字正则
   let replaceReg = new RegExp(this.search_text, 'g');
   // 高亮替换v-html值
   let replaceString = '<span class="search-text">' + this.search_text + '</span>';
   // 开始替换
   titleString = titleString.replace(replaceReg, replaceString);
  }
  return titleString;
  }
 },
 methods: {
  async add_cart(id){
  if (!this.isLogin) {
   this.$router.replace('/login');
  } else {
   var userId = this.$store.getters.getuname;
   var result = await addMyshopcart(id, userId)
   console.log(result.resMsg)

   if (result.res === 1) {
   this.$router.replace('/ShopCart/' + userId);
   } else {
   alert(result.resMsg)
   }
  }
  }
 }

 };
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style lang="less">
 @baseBlue: #0096ff;
 @com_gray1: #666;
 @com_gray2: #999;
.search-text{
 color: #52250a;
 background: #ffd930;
 font-size: .2rem;
 padding: .02rem;
 border-radius: 2px;
 vertical-align: top;
 margin-right: .04rem;
}


 .com_gray1 {
 color: @com_gray1;
 }

 .com_gray2 {
 color: @com_gray2;
 }

 .com_blue {
 color: @baseBlue;
 }

 /* 单个商家 */
 .one_business {
 background: #fff;

 .business_img {
  width: 1.6rem;
  height: 1.6rem;
  padding: 0.4rem;
  float: left;
  img {
  width: 100%;
  height: 100%;
  }
 }
 .business_info {
  float: right;
  width: 7.4rem;
  height: 1.6rem;
  padding: 0.4rem .2rem .4rem 0;
  .business_name {
  font-size: .35rem;
  line-height: .45rem;
  vertical-align: top;
  h3 {
   width: 5rem;
   display: inline-block;
   /*span {*/
   /*color: #52250a;*/
   /*background: #ffd930;*/
   /*font-size: .2rem;*/
   /*padding: .02rem;*/
   /*border-radius: 2px;*/
   /*vertical-align: top;*/
   /*margin-right: .04rem;*/
   /*}*/
  }
  .bzp {
   width: .3rem;
   height: .3rem;
   font-size: .26rem;
   text-align: center;
   line-height: .3rem;
   display: inline-block;
   color: @com_gray2;
   border: 0.01rem solid #ddd;
   padding: 0.01rem;
   border-radius: 3px;
   i {
   font-style: normal;
   }

  }
  }
  .business_code, .business_other {
  font-size: .25rem;
  margin-top: .3rem;
  line-height: .25rem;
  }

 }
 .code_num {
  svg {
  width: .3rem;
  height: .3rem;
  fill: #ffaa0c;
  }
 }
 .zsd {
  font-size: .25rem;
  height: .35rem;
  line-height: .3rem;
  padding: 0 0.05rem;
  display: inline-block;
  color: @baseBlue;
  background: #fff;
  border: 0.01rem solid @baseBlue;
  box-sizing: border-box;
  border-radius: 3px;
 }
 .fnzs {
  font-size: .25rem;
  height: .35rem;
  padding: 0 0.05rem;
  line-height: .3rem;
  display: inline-block;
  background: @baseBlue;
  color: #fff;
  border: 0.01rem solid @baseBlue;
  box-sizing: border-box;
  border-radius: 3px;
 }
 }
</style>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js获取图片长和宽度的代码
Nov 24 Javascript
jQuery滚动加载图片效果的实现
Mar 06 Javascript
jQuery中:input选择器用法实例
Jan 03 Javascript
解决jQuery使用JSONP时产生的错误
Dec 02 Javascript
JS实现简单的二维矩阵乘积运算
Jan 26 Javascript
基于jquery实现无限级树形菜单
Mar 22 Javascript
javascript弹出带文字信息的提示框效果
Jul 19 Javascript
react学习笔记之state以及setState的使用
Dec 07 Javascript
基于滚动条位置判断的简单实例
Dec 14 Javascript
WebGL three.js学习笔记之阴影与实现物体的动画效果
Apr 25 Javascript
详解vue更改头像功能实现
Apr 28 Javascript
express异步函数异常捕获示例详解
Nov 30 Javascript
Vue2.x通用编辑组件的封装及应用详解
May 28 #Javascript
JS拖动选择table里的单元格完整实例【基于jQuery】
May 28 #jQuery
小程序多图列表实现性能优化的方法步骤
May 28 #Javascript
实例详解带参数的 npm script
May 28 #Javascript
jquery实现Ajax请求的几种常见方式总结
May 28 #jQuery
Vue2.x通用条件搜索组件的封装及应用详解
May 28 #Javascript
jquery操作select常见方法大全【7种情况】
May 28 #jQuery
You might like
PHP 常见郁闷问题答解
2006/11/25 PHP
php实现用手机关闭计算机(电脑)的方法
2015/04/22 PHP
详解WordPress开发中过滤属性以及Sql语句的函数使用
2015/12/25 PHP
windows 2008r2+php5.6.28环境搭建详细过程
2019/06/18 PHP
零基础php编程好学吗
2019/10/11 PHP
javaScript Array(数组)相关方法简述
2009/07/25 Javascript
Prototype源码浅析 Number部分
2012/01/16 Javascript
formStorage 基于jquery的一个插件(存储表单中元素的状态到本地)
2012/01/20 Javascript
浅析JavaScript中的类型和对象
2013/11/29 Javascript
js父窗口关闭时子窗口随之关闭完美解决方案
2014/04/29 Javascript
原生javascript实现图片弹窗交互效果
2015/01/12 Javascript
jquery图片倾斜层叠切换特效代码分享
2015/08/27 Javascript
Node.js实现JS文件合并小工具
2016/02/02 Javascript
浅谈webpack下的AOP式无侵入注入
2017/11/12 Javascript
vue微信分享 vue实现当前页面分享其他页面
2017/12/02 Javascript
使用vue-router完成简单导航功能【推荐】
2018/06/28 Javascript
关于JavaScript中高阶函数的魅力详解
2018/09/07 Javascript
微信实现自动跳转到用其他浏览器打开指定APP下载
2019/02/15 Javascript
layui switch 开关监听 弹出确定状态转换的例子
2019/09/21 Javascript
js实现左右轮播图
2020/01/09 Javascript
浅析Python 中整型对象存储的位置
2016/05/16 Python
Python中函数eval和ast.literal_eval的区别详解
2017/08/10 Python
python3.6使用pymysql连接Mysql数据库
2018/05/25 Python
pyqt5 实现 下拉菜单 + 打开文件的示例代码
2019/06/20 Python
Python urllib2运行过程原理解析
2020/06/04 Python
Linux如何修改文件和文件夹的权限
2013/09/05 面试题
教师自荐信
2013/12/10 职场文书
物流专业求职信
2014/06/30 职场文书
学习张林森心得体会
2014/09/10 职场文书
南京市纪委监察局整改方案
2014/09/16 职场文书
办公室务虚会发言材料
2014/10/20 职场文书
2016中秋节晚会开场白
2015/11/26 职场文书
2016年小学植树节活动总结
2016/03/16 职场文书
2016年村干部公开承诺书(公开承诺事项)
2016/03/25 职场文书
如何写好闭幕词
2019/04/02 职场文书
用 Python 元类的特性实现 ORM 框架
2021/05/19 Python