Шаг 1 - Установим JS:
Для начало нам следует разместить в низ вашей страницы перед закрывающим тегом </body> следующий js:
JS
Code
<br><script src="http://istyle.pp.ua/img/color_code.js"></script> <br><script type="text/javascript"> <br>function selectCode(a){ <br>var e=a.parentNode.parentNode.getElementsByTagName('code')[0]; <br>if(window.getSelection){ <br>var s=window.getSelection(); <br>if(s.setBaseAndExtent){ <br> s.setBaseAndExtent(e,0,e,e.innerText.length-1); <br>}else{ <br>var r=document.createRange(); <br> r.selectNodeContents(e); <br> s.removeAllRanges(); <br> s.addRange(r);} <br>}else if(document.getSelection){ <br>var s=document.getSelection(); <br>var r=document.createRange(); <br> r.selectNodeContents(e); <br> s.removeAllRanges(); <br> s.addRange(r); <br>}else if(document.selection){ <br>var r=document.body.createTextRange(); <br> r.moveToElementText(e); <br> r.select();}} <br>// Замена Code на Выделить всё... <br> codediv=document.getElementsByTagName('div'); <br>for(i=0;i<codediv.length;i++){ <br>if(codediv[i].className=="bbCodeBlock"){ <br> s=codediv[i].innerHTML; <br> s=s.replace(/>Code</g,'><a href="#" onclick="selectCode(this);return false;">Выделить всё<\/a><').replace('<!--uzc-->','<!--uzc--><code>').replace('<!--\/uzc-->','<\/code><!--\/uzc-->'); <br> codediv[i].innerHTML=s;}} <br> $(function() {prettyPrint();}); <br></script>
Как вы понимаете мы с вами подключили основной скрипт отвечающий за подсветку синтаксиса кода uCoz и скрипт выделения кода в основной ячейки.
Шаг 2 - Установим CSS:
Теперь нам следует прописать css стили ячейки с кодом и саму подсветку определённых тегов, для белого варианта я решил создать подсветку схожую с подсветкой кода в программе Notepad++
CSS-Code
Code
/* Подсветка кода <br> ------------------------------------------*/ <br> div .codeMessage .nocode {background-color:none; color: #555 } <br> div .codeMessage .str {color: #cd5c5c } /* string - pink */ <br> div .codeMessage .kwd {color: #000080; font-weight: bold } <br> div .codeMessage .com {color: #00853E } /* comment - skyblue */ <br> div .codeMessage .typ {color: #00853E } /* type - lightgreen */ <br> div .codeMessage .lit {color: #cd5c5c } /* literal - darkred */ <br> div .codeMessage .pun {color: #555 } /* punctuation */ <br> div .codeMessage .pln {color: #555 } /* plaintext */ <br> div .codeMessage .tag {color: #5c71cd; font-weight: bold } /* html/xml tag - lightyellow */ <br> div .codeMessage .atn {color: #cd5c5c; font-weight: bold } /* attribute name - khaki */ <br> div .codeMessage .atv {color: #555} /* attribute value - pink */ <br> div .codeMessage .dec {color: #98fb98 } /* decimal - lightgreen */ <br><br>/* Specify class=linenums on a pre to get line numbering */ <br> ol.linenums { margin-top: 0; margin-bottom: 0; color: #AEAEAE } /* IE indents via margin-left */ <br> li.L0,li.L1,li.L2,li.L3,li.L5,li.L6,li.L7,li.L8 { list-style-type: none } <br><br>/* Alternate shading for lines */ <br> li.L1,li.L3,li.L5,li.L7,li.L9 { } <br><br>/* Выделение кода <br> ------------------------------------------*/ <br>/* webkit, opera, IE9 */ <br>.codeMessage ::selection { <br> background:#C0C0C0; <br>} <br>/* mozilla firefox */ <br>.codeMessage ::-moz-selection { <br> background:#C0C0C0; <br>}</div><div align="center">
Примечание:
Хочу отметить, что данное решение тестировалось в браузерах:
Firefox 12.0
Google Chrome 18.0
Opera 11.0
Apple Safariне меньше версии 5.1
Internet Explorer 8 и 9
В архиве вы найдёте два варианта подсветки синтаксиса кода uCoz, для светлого и тёмного дизайна сайта.
Плюсы данного решения:
Во-первых, адаптация под системный html код uCoz данного js, нам не надо прописывать вручную тег pre, достаточно воспользоваться стандартной функцией uCoz в bb панели, CODE.
Во-вторых, код отображается с отступами каждой строки, другие решения прописывают весь код в одно строку, что жутко неудобно.
В-третьих, мы получаем понятное копирование кода путём его выделения, нам не надо открывать дополнительные окна или подключать флеш плагин для его копирование в буфер.
Минусы данного решения:
Во-первых, большой вес основного js файла, 54кб, мне удалось его сжать до 22 кб в данном примере.
Во-вторых, при написании css кода в одну строку, цвет всего кода окрашивается в один цвет.
В целом на этом всё, спасибо за внимание!
Источник |
Автор: center-dm |
Категория: Другие скрипты для ucoz
| Добавил: FreeDom
| Дата: 15.05.2012
Другие новости |
Поделиться ссылкой
|