JS使用ActiveXObject實現(xiàn)用戶提交表單時屏蔽敏感詞功能
本例中敏感詞ciku.txt放在C盤根目錄下,采用的ActiveXObject插件獲取本地文件內(nèi)容。使用此插件不需網(wǎng)上下插件,直接用如下js代碼即可。
瀏覽器需修改interner安全選項的級別,啟用ActiveX才能獲取到代碼中的ActiveXObject插件。如下圖所示:
js代碼實現(xiàn)如下:
<script type="text/javascript"> // -------------- 全局變量,用來判斷文本域中是否包含臟詞,默認為false,即不包含臟詞------- var isDirty = false; //使用ActiveX讀取本地文件獲取dirtyword詞庫 function readFile(){ //var ForReading = 1; var fso = new ActiveXObject("Scripting.FileSystemObject"); openF = fso.OpenTextFile("c:\\ciku.txt", 1); var cikuStr= openF.ReadAll(); return cikuStr; } /* * 提交表單的主方法 * 在提交表單的時候?qū)?nèi)容進行過濾并在文本域顯示過濾后的內(nèi)容 */ function submitForm1() { var messageValue=document.getElementById("message").value; var cikuStr=readFile(); var cikuArr= new Array(); //定義數(shù)組,存儲敏感詞 cikuArr=cikuStr.split(" "); //敏感字符分割 for (var i=0;i<cikuArr.length;i++){ var flag=cikuArr[i]; if(messageValue.indexOf(flag)>=0){ //查找文本域中是否包含敏感字符,是則替換 filterWord(messageValue); var ifs=confirm("你的留言中含有不恰當(dāng)?shù)脑~語,系統(tǒng)已自動為你修改,是否繼續(xù)提交?"); break; }else{ //無敏感字符,直接提交表單 document.getElementById("message_board").submit(); break; } } if(ifs){ //用戶點擊確定,則提交表單 document.getElementById("message_board").submit(); } } /* * 對傳進來的messageValue過濾并返回新內(nèi)容 */ function filterWord(messageValue){ // 根據(jù)文本域的id獲取文本域?qū)ο髢?nèi)容 var cikuStr=readFile(); var cikuArr= new Array(); //定義數(shù)組,存儲敏感詞 cikuArr=cikuStr.split(" "); //敏感字符分割到數(shù)組內(nèi) for (var i=0;i<cikuArr.length;i++){ messageValue=filterOneWord(messageValue,cikuArr[i]);//filterOneWord函數(shù)每次替換一個字符,需循環(huán)調(diào)用 } document.getElementById("message").value=messageValue; //將替換后的內(nèi)容顯示到文本域中 } /* * 這個函數(shù)用來過濾單個詞語, 如果messageValue中含有oneDirtyWord, 則用"**"替換這個oneDirtyWord * messageValue --- 要過濾的語句 */ function filterOneWord(messageValue,oneDirtyWord){ var str=messageValue.replace(new RegExp(oneDirtyWord,'g'),"**"); return str; } </script>
表單部分代碼:
<body> <form name="message_board" id="message_board" action="aaa.html"> <textarea name="message" id="message" cols="50" rows="10"> "This is you post messsage" ——phpdream </textarea><br/> <input type="button" value="提交留言" id="submitMessage" onclick="submitForm1()"/> </form> </body>
- AngularJS表單提交實例詳解
- js表單提交和submit提交的區(qū)別實例分析
- 符合標準的js表單提交的代碼
- JavaScript使用ActiveXObject訪問Access和SQL Server數(shù)據(jù)庫
- JavaScript中使用ActiveXObject操作本地文件夾的方法
- js之ActiveX控件使用說明 new ActiveXObject()
- 原生js ActiveXObject獲取execl里面的值
- js借助ActiveXObject實現(xiàn)創(chuàng)建文件
- javascript下用ActiveXObject控件替換word書簽,將內(nèi)容導(dǎo)出到word后打印
相關(guān)文章
doctype后如何獲得body.clientHeight的方法
doctype后如何獲得body.clientHeight的方法...2007-07-07JavaScript實現(xiàn)將UPC轉(zhuǎn)換成ISBN的方法
這篇文章主要介紹了JavaScript實現(xiàn)將UPC轉(zhuǎn)換成ISBN的方法,涉及javascript字符串操作的相關(guān)技巧,需要的朋友可以參考下2015-05-05JavaScript 經(jīng)典實例日常收集整理(常用經(jīng)典)
本文是小編日常收集整理些js經(jīng)典實例,非常具有參考借鑒價值,需要的朋友一起了解了解吧2016-03-03js change,propertychange,input事件小議
github上關(guān)于mootools一個issue的討論很有意思,所以就想測試記錄下。感興趣的可以點擊原頁面看看2011-12-12Javascript實現(xiàn)DIV滾動自動滾動到底部的代碼
一個比較特殊的客戶要求,在一個頁面用表格顯示數(shù)據(jù),數(shù)據(jù)量不是很多,不希望使用瀏覽器的滾動條,只能在Div中滾動table中的數(shù)據(jù),但是有個特殊的要求,就是必須將滾動條自動滾動到底部2012-03-03JS是否可以跨文件同時控制多個iframe頁面的應(yīng)用技巧
這篇文章給大家詳細介紹了JS是否可以跨文件同時控制多個iframe頁面的應(yīng)用技巧,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧2007-12-12