您好,登錄后才能下訂單哦!
這篇文章主要介紹如何使用js正則匹配table,img及去除各種標(biāo)簽問(wèn)題,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
核心代碼
//獲取公示欄內(nèi)容 s = "$row.detail$"; mainContent =s; //如果有多個(gè)table使用下面注釋的正則只會(huì)匹配成一個(gè)table //var tabReg = /<table[^>]*>((?!table).)*<\/table>/gi; //匹配單個(gè)table var tabReg = /<table[^>]*>\s*(<tbody[^>]*>)?(\s*<tr[^>]*>[\s\S]*?<\/tr>\s*)*(<\/tbody>)?\s*<\/table>/gi; var tabMatch = tabReg.test(s); var tabMatchContentArray = s.match(tabReg); if(tabMatch) { mainContent = s.replace(tabReg,"#"); } //對(duì)img標(biāo)簽進(jìn)行匹配 var imgReg = /<img.*?(?:>|\/>)/gi; imgMatchContentArray = s.match(imgReg); if(imgReg.test(s)) { //將img標(biāo)簽替換為* mainContent = mainContent.replace(imgReg,"*"); } //處理html標(biāo)簽 mainContent = mainContent.replace(/ /gi," "); var pReg1 = /<p>/gi; var pReg2 = /<\/p>/gi; mainContent = mainContent.replace(pReg1,"").replace(pReg2,"<br />"); //下面的htmlReg1 ,htmlReg2可以匹配任意標(biāo)簽 // var htmlReg1 =/<[^>]+>/gi; // var htmlReg2 =/<(.+?)[\s]*\/?[\s]*>/gi; // // mainContent = mainContent.replace(htmlReg1,"").replace(htmlReg2,""); //mainContent = mainContent.replace(/&/gi,"<p>").replace(/@/gi,"</p>"); var pageIndex = 1; var size = 500; var tableContentArray = mainContent.split("#"); var array = []; //存放以table分割后的數(shù)組中每個(gè)數(shù)組可以分作幾頁(yè) var arrayIndex = []; //存放table在內(nèi)容中的索引 var len =0; for(var i=0;i<tableContentArray.length;i++) { var con = tableContentArray[i]; len += con.length; arrayIndex[i] = len; array[i] = Math.ceil(con.length /size); } var tableIndexArray = [];//存放table內(nèi)容頁(yè)碼數(shù) var sum = 1; for(var j=0;j<array.length-1;j++) { sum += array[j]; tableIndexArray[j] = sum; } var currentPageContent = mainContent.substr((pageIndex-1)*size,size); if(tableIndexArray.indexOf(pageIndex) >= 0) { currentPageContent = tabMatchContentArray[tableIndexArray.indexOf(pageIndex)]; } if(currentPageContent.indexOf("#")!= -1) { var beginToCurrentPageContent = mainContent.substr(0,pageIndex*size); var tabLastIndex = beginToCurrentPageContent.lastIndexOf("#"); currentPageContent = currentPageContent.substr(0,tabLastIndex-(pageIndex-1)*size); //當(dāng)前頁(yè)是否有 * 獲取最后一個(gè) * 的位置 var indexOf = currentPageContent.indexOf("*"); if(indexOf >= 0) { //獲取開(kāi)始到當(dāng)前頁(yè)位置的內(nèi)容 中的 * 的最后的下標(biāo) var reCount = beginToCurrentPageContent.split("*").length - 1; var contentArray = currentPageContent.split("*"); currentPageContent = replaceImgContent(contentArray,reCount,imgMatchContentArray); } } else { //當(dāng)前頁(yè)是否有 * 獲取最后一個(gè) * 的位置 var indexOf = currentPageContent.indexOf("*"); if(indexOf >= 0) { //獲取從開(kāi)始位置到當(dāng)前頁(yè)位置的內(nèi)容 var beginToCurrentPageContent = mainContent.substr(0,pageIndex*size); //獲取開(kāi)始到當(dāng)前頁(yè)位置的內(nèi)容 中的 * 的最后的下標(biāo) var reCount = beginToCurrentPageContent.split("*").length - 1; var contentArray = currentPageContent.split("*"); currentPageContent = replaceImgContent(contentArray,reCount,imgMatchContentArray); } } if(currentPageContent=="") { alert("頁(yè)碼數(shù)超過(guò)范圍"); } else { document.getElementById("annouContent").innerHTML= currentPageContent; } /* currentArray:當(dāng)前頁(yè)以 * 分割后的數(shù)組 replaceCount:從開(kāi)始內(nèi)容到當(dāng)前頁(yè)的內(nèi)容 * 的個(gè)數(shù) matchArray : img標(biāo)簽的匹配的內(nèi)容 */ function replaceImgContent(currentArray,replaceCount,matchArray) { var result = ""; for(var i=currentArray.length -1,j = replaceCount-1 ;i>=1; i--) { var temp = (matchArray[j] + currentArray[i]); result = temp + result; j--; } result = currentArray[0] + result ; return result; } </script>
下面是一些補(bǔ)充
js正則匹配刪除table
var reg = /<[\/]*(table|td|tr)[ a-zA-z=''""]*>|123/g
一個(gè)JAVASCRIPT正則表達(dá)式,Table中只保留ColSpan和RowSpan
html = html.replace(/<(TBODY|THEAD|TFOOT|TH|TR|TD)[^>]*?(ColSpan\s*=\s*["']?[^"'>\s]*["']?[^>]*?)?(RowSpan\s*=\s*["']?[^"'>\s]*["']?[^>]*?)?>/gi,"<$1 $2 $3>");
以上是“如何使用js正則匹配table,img及去除各種標(biāo)簽問(wèn)題”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。