前端过滤关键字

简介:


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Typecontent="text/html; charset=gb2312" />

<title>关键字快速搜索</title>

<style>

body

{

font-size: 14px;

}



h2

{

display: inline;

margin: 0;

}



#spnKeyNum, #spnWordNum

{

color: #F00;

}



#spnList a

{

font-size: 12px;

color: #0000FF;

}



#spnTime

{

color: #600;

}



textarea, #divDisplay

{

margin: 0;

padding: 0;

font-size: 14px;

display: block;

background: #EEE;

border: #999 solid 1px;

}



#txtKeys

{

width: 95%;

height: 100px;

}



#txtContent, #divDisplay

{

height: 400px;

width: 95%;

}



#divDisplay

{

display: none;

overflow: auto;

}



#divDisplay em

{

color: #F00;

font-style: normal;

}



#divFoot

{

padding: 5px;

width: 95%;

}



#spnLable2

{

margin: 5px;

float: left;

color: #690;

}



button

{

float: left;

}



#desc

{

color: #333;

float: right;

}

</style>

</head>



<body onload="handleLoad();">

<div id="divTop">

<h2>关键字</h2>

<span id="spnLable1">(<span id="spnKeyNum">0</span>个)</span>

<span id="spnList">

<a href="javascript:load('city.txt');">世界城市</a>

<a href="javascript:load('words.txt');">部分英文单词</a>

<a href="javascript:load('idiom.txt');">成语全集</a>

</span>

</div>

<div id="divMain">

<textarea id="txtKeysonchange="handleKeyChange();"></textarea>

<h2>内容</h2>

<span id="spnLable1">(<span id="spnWordNum">0</span>字)</span>

<textarea id="txtContentonchange="handleContentChange();"></textarea>

<div id="divDisplay"></div>

</div>

<div id="divFoot">

<span id="spnLable2">搜索用时: <span id="spnTime">0</span>ms</span>

<button id="btnStartonclick="handleClick();"> 测试</button>

<button id="btnResetonclick="reset()disabled="disabled"> 重置</button>

<span id="desc">EtherDream 2009</span>

</div>



<script>

var tblRoot;



/*

* 函数: makeTree

* 注释: 将关键字生成一颗树

*/

function makeTree()

{

var strKeys = objKeys.value;

var arrKeys = strKeys.split("");

var tblCur = tblRoot = {};

var key;



for(var i=0,n=arrKeys.length; i<n; i++)

{

key = arrKeys[i];



if(key == ';') //完成当前关键字

{

tblCur.end = true;

tblCur = tblRoot;

continue;

}



if(key in tblCur) //生成子节点

tblCur = tblCur[key];

else

tblCur = tblCur[key] = {};

}



tblCur.end = true; //最后一个关键字没有分割符

}



/*

* 函数: search

* 注释: 标记出内容中关键字的位置

*/

function search(content)

{

var tblCur;

var i = 0;

var n = content.length;

var p, v;

var arrMatch = [];



while(i < n)

{

tblCur = tblRoot;

p = i;

v = 0;



for(;;)

{

if(!(tblCur = tblCur[content.charAt(p++)]))

{

i++;

break;

}



if(tblCur.end) //找到匹配关键字

v = p;

}



if(v) //最大匹配

{

arrMatch.push(i-1, v);

i = v;

}

}



return arrMatch;

}

</script>



<script>

var $ = function(id){return document.getElementById(id)};



var objKeys = $("txtKeys");

var objContent = $("txtContent");

var objDisplay = $("divDisplay");

var bKeyChanged = false;





function handleKeyChange()

{

var str = objKeys.value;

var n;



if(str.length==0)

n = 0;

else

n = str.split(";").length;



/*

* 显示关键字数量

*/

$("spnKeyNum").innerHTML = n;



bKeyChanged = true;

}



function handleContentChange()

{

/*

* 显示内容长度

*/

$("spnWordNum").innerHTML = objContent.value.length;

}



function handleLoad()

{

handleKeyChange();

handleContentChange();

}



function handleClick()

{

var strContent = objContent.value;

var arrMatch;

var arrHTML = [];

var strHTML;

var mid;

var p = 0;





$("btnStart").disabled = true;

$("btnReset").disabled = false;



if(bKeyChanged)

{

makeTree();

bKeyChanged = false;

}



/*

* 开始搜索!

*/

var t = +new Date();



arrMatch = search(strContent);



/*

* 搜索用时

*/

$("spnTime").innerHTML = +new Date() - t;



/*

* 标记关键字

*/

for(var i=0,n=arrMatch.length; i<n; i+=2)

{

mid = arrMatch[i];

arrHTML.push(strContent.substring(p, mid),

"<em>",

strContent.substring(mid, p = arrMatch[i+1]),

"</em>");

}

arrHTML.push(strContent.substring(p));



strHTML = arrHTML.join("").replace(/\n/g, "<br>");



/*

* 显示结果

*/

objDisplay.innerHTML = strHTML;



objContent.style.display = "none";

objDisplay.style.display = "block";

}



function reset()

{

$("btnStart").disabled = false;

$("btnReset").disabled = true;



objContent.style.display = "block";

objDisplay.style.display = "none";

}



function load(file)

{

/*

* 创建HTTP组件

*/

if(window.ActiveXObject)

{

objHttp = new ActiveXObject("Microsoft.XMLHTTP");

}

else

{

objHttp = new XMLHttpRequest();

objHttp.overrideMimeType("text/xml");

}



objHttp.onreadystatechange = function()

{

if(objHttp.readyState != 4)

return;



objKeys.value = objHttp.responseText;

handleKeyChange();

};



/*

* 发送请求

*/

objHttp.open("GET", file, true);

objHttp.send(null);

}



</script>

</body>

</html>


本文转自程序猿博客51CTO博客,原文链接http://blog.51cto.com/haihuiwei/1968703如需转载请自行联系原作者


365850153

相关文章
|
前端开发 JavaScript
前端基础 - JavaScript之this关键字
前端基础 - JavaScript之this关键字
51 0
|
2月前
|
存储 前端开发 JavaScript
前端:new关键字的作用
在JavaScript中,`new`关键字用于创建构造函数或类的新实例。使用`new`时,会自动创建一个空对象,并将其绑定到函数内的`this`,执行构造函数中的代码后返回该对象。这使得对象可以继承构造函数的属性和方法。
|
8月前
|
前端开发 JavaScript
前端 JS 经典: 富文本高亮关键字
前端 JS 经典: 富文本高亮关键字
146 0
|
前端开发 JavaScript
前端开发领域中,require和import这两个重要的关键字到底有啥区别?
前端开发领域中,require和import这两个重要的关键字到底有啥区别?
177 3
|
前端开发
前端学习笔记202306学习笔记第四十三天-await关键字2
前端学习笔记202306学习笔记第四十三天-await关键字2
68 0
|
前端开发
前端学习笔记202306学习笔记第四十三天-await关键字
前端学习笔记202306学习笔记第四十三天-await关键字
56 0
|
前端开发
前端学习笔记202306学习笔记第四十三天-await关键字3
前端学习笔记202306学习笔记第四十三天-await关键字3
72 0
|
前端开发 JavaScript
前端祖传三件套JavaScript的最基础之关键字
在前端开发中,JavaScript作为一门重要的编程语言,广泛应用于网页的交互和动态效果的实现。作为最基础的部分,关键字是了解和掌握JavaScript编程必不可少的部分。本文将为大家介绍JavaScript中最基础的关键字,包括变量声明、条件语句、循环语句等。
115 0
|
前端开发 JavaScript
【ES6丨前端进阶基础 】ES6的关键字,新特性以及解构赋值
【ES6丨前端进阶基础 】ES6的关键字,新特性以及解构赋值
151 0
【ES6丨前端进阶基础 】ES6的关键字,新特性以及解构赋值
|
前端开发 JavaScript
前端经典面试题解密:JS的new关键字都干了什么?
new关键字在实例化获取对象时都做了什么?是一道经常出现在前端面试时的问题。如果只是简单的了解new关键字是实例化构造函数获取对象,是万万不能够的。更深入的层级发生了什么呢?同时面试官想从这道题里面考察什么呢?下面胡哥为各位小伙伴一一来解密。
345 0
下一篇
开通oss服务