vue2自定义指令directive用法: dom中关键字文字高亮

vue2自定义指令directive: 关键字文字高亮

大概是这样的效果,具体看请参考下面的写法:

一、步骤 1: 编写自定义指令文件

确保你的自定义指令逻辑能够正确处理从变量中传递的值。指令的实现不需要更改,因为它已经支持动态传递高亮文本。

创建js文件:highlight.js

javascript 复制代码
export default {
  inserted: function (el, binding) {
    highlightText(el, binding.value, binding.arg || 'highlight');
  },
  update: function (el, binding) {
    highlightText(el, binding.value, binding.arg || 'highlight');
  }
};

function highlightText(element, textToHighlight, highlightClass) {
  const walker = document.createTreeWalker(element, NodeFilter.SHOW_TEXT);
  let node;
  
  // 先移除之前的高亮
  const highlights = element.querySelectorAll(`.${highlightClass}`);
  highlights.forEach(highlight => {
    const parent = highlight.parentNode;
    parent.replaceChild(document.createTextNode(highlight.textContent), highlight);
    parent.normalize();
  });
  
  // 添加新的高亮
  while ((node = walker.nextNode())) {
    const text = node.nodeValue;
    const regex = new RegExp(textToHighlight, 'gi');
    const newHTML = text.replace(regex, match => 
      `<span class="${highlightClass}">${match}</span>`
    );
    
    if (newHTML !== text) {
      const temp = document.createElement('span');
      temp.innerHTML = newHTML;
      node.parentNode.replaceChild(temp, node);
    }
  }
}

二、步骤 2: 在main.js中引入指令

确保指令在main.js中已正确引入和注册。

javascript 复制代码
import Vue from 'vue';
import App from './App.vue';

import highlightDirective from './highlight'; // 确保路径正确
// 注册全局指令
Vue.directive('highlight', highlightDirective);

new Vue({
  render: h => h(App),
}).$mount('#app');

三、步骤 3: 在组件中定义变量

首先,在组件中定义一个变量,用于存储需要高亮的文本。

javascript 复制代码
<template>
  <div v-highlight="highlightText" class="content">
    这里是一些包含个人信息的文本,个人信息需要被高亮显示。
  </div>
</template>
 
<script>
export default {
  name: 'HighlightExample',
  data() {
    return {
      highlightText: '个人信息' // 定义需要高亮的文本
    };
  }
}
</script>
 
<style>
.highlight {
  background-color: yellow;
  font-weight: bold;
}
</style>
相关推荐
南屿im31 分钟前
把代码变成“可改的树”:一文读懂前端 AST 的原理与实战
前端·javascript
charlie11451419134 分钟前
从《Life of A Pixel》来看Chrome的渲染机制
前端·chrome·学习·渲染·浏览器·原理分析
HWL567940 分钟前
输入框内容粘贴时 &nbsp; 字符净化问题
前端·vue.js·后端·node.js
梦65043 分钟前
JQ 的 AJAX 请求方法
前端·ajax
ObjectX前端实验室44 分钟前
【react18原理探究实践】分层解析React Fiber 核心工作流程
前端·react.js
IT_陈寒1 小时前
「JavaScript 性能优化:10个让V8引擎疯狂提速的编码技巧」
前端·人工智能·后端
ObjectX前端实验室2 小时前
【react18原理探究实践】scheduler原理之Task 完整生命周期解析
前端·react.js
ObjectX前端实验室2 小时前
【react18原理探究实践】调度器(Scheduler)原理深度解析
前端·react.js
路漫漫心远2 小时前
音视频学习笔记十八——图像处理之OpenCV检测
前端
摸着石头过河的石头2 小时前
从零开始玩转前端:一站式掌握Web开发基础知识
前端·javascript