Heim >Web-Frontend >js-Tutorial >Wie kann ich Text mit jQuery hervorheben?
Text mit jQuery hervorheben
Problembeschreibung:
Sie möchten ein bestimmtes Wort hervorheben innerhalb eines bestimmten Textblocks mit jQuery.
Lösung:
Um ein Wort mit jQuery hervorzuheben, können Sie Plugins wie Highlight oder die unten bereitgestellte aktualisierte Version des Originalskripts verwenden:
jQuery.fn.highlight = function (pat) { function innerHighlight(node, pat) { var skip = 0; if (node.nodeType == 3) { var pos = node.data.toUpperCase().indexOf(pat); if (pos >= 0) { var spannode = document.createElement('span'); spannode.className = 'highlight'; var middlebit = node.splitText(pos); var endbit = middlebit.splitText(pat.length); var middleclone = middlebit.cloneNode(true); spannode.appendChild(middleclone); middlebit.parentNode.replaceChild(spannode, middlebit); skip = 1; } } else if (node.nodeType == 1 && node.childNodes && !/(script|style)/i.test(node.tagName)) { for (var i = 0; i < node.childNodes.length; ++i) { i += innerHighlight(node.childNodes[i], pat); } } return skip; } return this.length && pat && pat.length ? this.each(function () { innerHighlight(this, pat.toUpperCase()); }) : this; }; jQuery.fn.removeHighlight = function () { return this.find("span.highlight").each(function () { this.parentNode.firstChild.nodeName; with (this.parentNode) { replaceChild(this.firstChild, this); normalize(); } }).end(); };
Alternativer Ansatz:
Wenn Sie einen neueren und funktionsreicheren Ansatz bevorzugen Um die Lösung zu finden, ziehen Sie das folgende Plugin in Betracht:
jQuery.extend({ highlight: function (node, re, nodeName, className) { if (node.nodeType === 3) { var match = node.data.match(re); if (match) { var highlight = document.createElement(nodeName || 'span'); highlight.className = className || 'highlight'; var wordNode = node.splitText(match.index); wordNode.splitText(match[0].length); var wordClone = wordNode.cloneNode(true); highlight.appendChild(wordClone); wordNode.parentNode.replaceChild(highlight, wordNode); return 1; //skip added node in parent } } else if ((node.nodeType === 1 && node.childNodes) && // only element nodes that have children !/(script|style)/i.test(node.tagName) && // ignore script and style nodes !(node.tagName === nodeName.toUpperCase() && node.className === className)) { // skip if already highlighted for (var i = 0; i < node.childNodes.length; i++) { i += jQuery.highlight(node.childNodes[i], re, nodeName, className); } } return 0; } }); jQuery.fn.unhighlight = function (options) { var settings = { className: 'highlight', element: 'span' }; jQuery.extend(settings, options); return this.find(settings.element + "." + settings.className).each(function () { var parent = this.parentNode; parent.replaceChild(this.firstChild, this); parent.normalize(); }).end(); }; jQuery.fn.highlight = function (words, options) { var settings = { className: 'highlight', element: 'span', caseSensitive: false, wordsOnly: false }; jQuery.extend(settings, options); if (words.constructor === String) { words = [words]; } words = jQuery.grep(words, function (word, i) { return word != ''; }); words = jQuery.map(words, function (word, i) { return word.replace(/[-[\]{}()*+?.,\^$|#\s]/g, "\$&&"); }); if (words.length == 0) { return this; }; var flag = settings.caseSensitive ? "" : "i"; var pattern = "(" + words.join("|") + ")"; if (settings.wordsOnly) { pattern = "\b" + pattern + "\b"; } var re = new RegExp(pattern, flag); return this.each(function () { jQuery.highlight(this, re, settings.element, settings.className); }); };
Dieses Plugin bietet zusätzliche Funktionen wie die Möglichkeit, benutzerdefinierte Tag-Namen und Klassennamen für die hervorgehobenen Elemente anzugeben, nach mehreren Begriffen gleichzeitig zu suchen und Suchen unter Berücksichtigung der Groß-/Kleinschreibung durchzuführen . Es enthält auch eine Methode zum Entfernen vorhandener Hervorhebungen.
Das obige ist der detaillierte Inhalt vonWie kann ich Text mit jQuery hervorheben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!