搜索关键字高亮,正则实现 || Jquery实现

本文介绍了如何使用Vue.js和jQuery分别实现文本搜索并高亮显示搜索关键词。HTML中通过v-html和JavaScript的replace方法实现,而jQuery则通过DOM操作和正则表达式来替换匹配内容。
摘要由CSDN通过智能技术生成
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>t2</title>
    <script src="vue.js"></script>
</head>
<body>
    <div class="d">
    	<h3 v-html="filterA(text)"></h3>
    </div>
    <script>
        new Vue({
        	el: '.d',
        	data(){
        		return {
        			text: 'huxianghuxianghuxianghuxiangHUxiang',
        			search: 'hu'
        		}
        	},
        	methods: {
        		filterA(t){
        			let r = t.replace(eval(`/(${this.search})/g`), `<span style="color:#f4aa2f">${this.search}</span>`);
        			return r;
        		}
        	}
        })
    </script>
</body>
</html>

Jquery实现

(function($) {
	$.fn.GL = function(options) {
		var dataop = {
			ocolor: 'red',
			oshuru: '����',
		};
		var chuancan = $.extend(dataop, options);
		$(this).each(function() {
			var _this = $(this);
			_this.find($(".glnow")).each(function() {
				$(this).css({
					color: ""
				});
			});
		});
		if (chuancan.oshuru == '') {
			return false;
		} else {
			$(this).each(function() {
				var _this1 = $(this);
				var html = _this1.html();
				var newHtml = html.replace(chuancan.oshuru, 
				'<span class="glnow" style="color:' + chuancan.ocolor + '">' + chuancan.oshuru +'</span>');
				_this1.html(newHtml);
			});
		}
	}
})(jQuery);
/*再到调用页面初始化*/
$('.high-light').GL({
   ocolor: '#f4aa2f',
   oshuru: this.search
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值