日期:2014-05-17 浏览次数:20767 次
前端代码加亮插件(html,jss,css),支持即时加亮,运行代码
http://bbs.51js.com/viewthread.php?tid=88379
?
html混合css js语法加亮,
支持即时运行,即时编辑
在代码区点击鼠标右键执行对应功能!
详情见http://tree88.com/?post=4[博客论坛语法加亮插件]
<script charset="gbk" src="http://jsbaba.com/tool/lightcode/lc.js"></script> 直接加亮 <textarea class="lang-html"> <!doctype html> <html> <head> <meta charset="gbk"/> <title>语法加亮插件例子</title> <style> /*内嵌样式*/ h1{ padding:8px;margin:0; border:1px solid #ddd; } </style> <script src="http://jsbaba.com/tool/lightcode/lc.js"></script> <script> /*内嵌js*/ function hello(){ var txt=new Array('h','e','l','l','o'); onload=function(){ for(var i=0;i<txt.length;i++){ alert(txt[i]); } }; } hello(); </script> </head> <body> <div> <h1 style="color:green;">html加亮例子</h1> <!--<p>html注释</p>--> </div> </body> </html> </textarea> 编辑加亮,下面附上加亮插件源代码 <textarea class="lang-js eidt"> $plugin(function(){ $lightcode=function(){ var metaChar='`',//元字符 stxt='0123456789abcdefghijklmnopqrstuvwxyz'.split(''), splitHTML=/(<script[^>]*?>[\s\S]*?<\/script>)|(<style[^>]*?>[\s\S]*?<\/style>)|(<textarea[^>]*?>[\s\S]*?<\/textarea>)|(<[\w]+[^>]*?>|<\/[\w]+>)|(<!--[\s\S]*?-->)|(<!doctype[^>]*?>)|(\n)/gi,//html正则 splitCSS=/(\{[^\}]*\})|(<!--[\s\S]*?-->)|(\n)|([^\n]+)/g,//css正则 splitJS=/('[\w\W]*?')|("[\w\W]*?")|(\/\*[\w\W]*?\*\/)|(\/\/[\w\W]*?\n)|(?:[\(\[:=,])\s*(\/[^\n]+?\/[gim]{0,3})|\b(break|delete|function|return|typeof|case|do|if|switch|var|catch|else|in|this|void|continue|false|instanceof|throw|while|debugger|finally|new|true|with|default|for|try)\b|\b(Date|Function|Array|Object|Boolean|Global|Math|Number|RegExp|Error|String)\b|\b(undefined|\d+|eval|onload|parseInt|setTimeout|setInterval|clearInterval|alert)\b|(\n)/g,//js正则 beReplaceCharG=[/\\'/g,/\\"/g,/\\\//g,/\\\\/g],//需要被替换的特殊字符 beReplaceCharS=['\\\'','\\\"','\\\/','\\\\'];//需要被替换的特殊字符 var $=$dom_id, $=$dom_selector, $encode=$string_encodeHTML, $each=$object_each, $getTop=$dom_getTop, $isWrap=$dom_isWrap, $ready=$event_ready, $addCss=$bom_addCss; function langJS(text_source){ var replaceSource={},//被替换的资源列表 i=beReplaceCharS.length, stxtI=-1; while(i--){ if(text_source.indexOf(beReplaceCharS[i])>-1){//找到对应需要被替换的字符 while(1){ if(text_source.indexOf(metaChar+stxt[++stxtI])==-1){ replaceSource[metaChar+stxt[stxtI]]=i; text_source=text_source.replace(beReplaceCharG[i],metaChar+stxt[stxtI]); break; } } } } text_source=(text_source+'\n') .replace(/&/g,'&') .replace(/</g,'<') .replace(/>/g,'>') .replace(/\t/g,' ') .replace(/ /g,' ') .replace(splitJS,function(a){ switch(true){ case !!arguments[1]:;//单引号 case !!arguments[2]:return '<q>'+a.replace(/\n/g,function(a){ return '</q></li><li><q>' })+'</q>';//双引号 case !!arguments[3]:return '<s>'+a.replace(/\n/g,function(a){ return '</s></li><li><s>'