« Поставить закладку » « Сделать стартовой »

« Форумы » « Блоги » « Статьи » « Новости » « Файлы » « Realcoding IRC » « Site map » « Поиск »


Главная Главная
Анонсы Анонсы
Форумы Форумы
Каталог Каталог
Поиск Поиск
Опросы Опросы
Книжный магазин Книжный магазин
Реклама на сайте
Публикации Публикации
Партнеры Партнеры
Карта Карта сайта
Рассылки Рассылки
RSS экспорт
Настройки Настройки
О нас пишут О нас пишут
Контакты Контакты
Гостевая книга Гостевая книга

Тестирование 64-битных приложений

ПнВтСрЧтПтСбВс
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30          
    Популярное
Хранитель Экрана на Visual Basic

Oracle и PHP - это очень просто

Константы

RFC 1521. MIME - Multipurpose Internet Mail Extensions

Изучаем ассемблер в Delphi.

Префиксы

Закругление углов без использования изображений

Создание псевдонима с указанием пути к папке с базой

Развитие класса документа

Связка ActiveX - Internet Explorer




    Архив файлов



    Сообщества



    Документация

Статьи:: Интернет технологии :: Java Script :: Подсветка синтаксиса малыми средствами


отправить ссылку другу версия для печати  Обсудить на форуме

Подсветка синтаксиса малыми средствами



html-кодинге практически все можно сделать по крайней мере двумя способами: медленно и некрасиво или быстро и красиво. Другими словами - элегантно, когда сравнительно компактный код отображается корректно в наиболее известных браузерах. Другое дело, что html не во всех случаях соответствует запросам. Тогда уже на помощь приходят различные "примочки", называемые фреймуорками. Однако о фреймуорках мы говорить не будем (хотя для обсуждения это очень интересная тема). Речь пойдет о более широком, в общем-то, понятии - о JavaScript.



Love story

В статьях, публикуемых на сайте, я довольно часто привожу отрывки (листинги) различного кода. За оформление кода отвечает следующий элемент:

.preview {padding:1em 25px .3em;margin:0;border-left:3px solid #cfcfa5;background:#fafaed;}

Все бы хорошо, но этот способ имеет несколько недостатков: нет подсветки синтаксиса и нумерации строк, а весь код, если его не форматируешь, сбивается в некий бесформенный массив. В принципе, проблема не столь глобальна, но недавно я нашел средство под названием SyntaxHigh-lighter и убедился, что можно сделать, как я уже говорил, красиво и удобно. Этот способ подсветки я впервые заметил на портале Yahoo Developer Network (developer.yahoo. com), после чего сразу же сохранил одну из страниц:). В содержании .js-файлов стояла ссылка www.dreamprojections. com/syntaxhighlighter/, где я и нашел то, что было нужно. SyntaxHighlighter поддерживает чуть более 10 разных языков включая CSS, PHP, AQL, Ruby, Java и др. Подсветка и нумерация и прочие удобства - все включено.

Практика

Сразу же обращаю ваше внимание: подсветка не "светит" без включенной опции JavaScript. Скорее всего, у большинства интернетчиков данная опция включена, так как далеко не все знают, что это такое:). С другой стороны, на вашем сайте, посвященном какому бы то ни было программированию, такие "незнающие" люди вряд ли появятся. В таком случае вам придется честно уведомить их, например, где-нибудь в footer'e web-страницы о том, что JavaScript выключать нежелательно. Во всей мощи SyntaxHighlighter занимает 40 Kb, а если убрать ненужные скрипты - раза в два меньше... Да ну этот минимализм:)! Я лучше объясню вам, как внедрить SyntaxHighlighter в web-страницы. Мой "проектный" сайт базируется на Snews, поэтому стартовая страница - index.php (на самом деле это xhtml). В конце файла перед тегом </body> я прописал:

<script language="javascript" src="js/sh Core.js"></script>
<script language="javascript" src="js/sh BrushCSS.js"></script>
<script language="javascript" src="js/sh BrushPhp.js"></script>
<script language="javascript" src="js/sh BrushCSharp.js"></script>
<script language="javascript" src="js/sh BrushXml.js"></script>
<script language="javascript">
dp.SyntaxHighlighter.HighlightAll('code');
</script>

Как видите, я инициализировал только те скрипты (т.е. ту подсветку), которые буду использовать в дальнейшем. Кроме того, не забываем о ядре shCore.js - его подключаем обязательно. Нужные скрипты вы найдете в папке scripts/. Скопировав их на свой сайт, проверьте, правильно ли указаны все имена и пути. Как видно в вышеизложенном коде, я поместил скрипты в директорию /js. Далее подключаем стилевой файл:

<link type="text/css" rel="stylesheet" href="template/SyntaxHighlighter.css"></link>

Собственно, вот и вся подготовка к будущей верстке. А сейчас пару слов о разметке: как оформить код, чтобы он выводился через Syntax-Highlighter. В разделе Wiki на сайте www.dreamprojections. com/syntaxhighlighter/ описываются два способа:

1. С помощью тега <pre> и атрибутов code и class:
<pre name="code" class="html">
... наш код ...
</pre>

Важная деталь: непосредственно в том коде, который вы собираетесь выводить, скобки нужно заменить на &lt; (html-аналог "<") и &gt; (вместо ">"). Для надежности я также заменяю одинарную кавычку ' на &#39;.

2. С помощью тега <textarea>:
<textarea name="code" class="c#" cols="60" rows="10">
... наш код ...
</textarea>

Это менее надежный вариант: в результате есть риск увидеть совсем не то, чего хотелось. Не советую использовать в паре с TinyMCE (такой wysiwyg-редактор, для справки) или RSS. Я думаю, одно другого не стоит. Посредством атрибута class мы можем управлять выводом кода. Пример:

<pre name="code" class="html:атрибут1: атрибут2:...">
... код ...
</pre>

Перечень атрибутов

 

  • nogutter - не отображать нумерацию строк
  • nocontrols - не показывать верхнюю строку
  • collapse - показывать код в свернутом виде
  • firstline[число] - номер первой строки. По умолчанию равен 1 :)
  • showcolumns - деление на столбцы

Языковые алиасы

Когда я говорил о выводе уже отформатированного текста, то упомянул html:
<pre name="code" class="html">

Разумеется, это не единственный вариант подсветки синтаксиса - в SyntaxHighlighter'е за это отвечают языковые псевдонимы (алиасы, англ.: aliases), и "html" - только один из них. В каждом подключаемом *.js-файле содержится по нескольку алиасов: как вы понимаете, они сгруппированы по общности регулярных выражений. Примеры: файл shBrushCpp.js - псевдонимы 'cpp', 'c', 'c++'; shBrushRuby.js - 'ruby', 'rails', 'ror' и т.д. В общем, смотрите соответствующую таблицу на сайте поддержки.

Альтернатива?

В ходе написания статьи я встретил похожий скрипт для подсветки синтаксиса. Называется он Google Code Prettifier, скачать его можно по адресу www.google-code-prettify.googlecode.com. Отличие SyntaxHighlighter'а - он несколько проще в "обслуживании". Хотя, казалось бы, куда уж проще? Подключение осуществляется таким образом. В индексный файл пишем:

<link href="prettify.css" type="text/css" rel="stylesheet" />
<script type="text/javascript" src="prettify. js"></script>

Пути к файлам должны соответствовать тому, куда вы эти файлы скопировали. Кроме этого, в документ необходимо добавить тег

<body onload="prettyPrint()">

Все, код можно выводить через

<pre class="prettyprint">...</pre>
или
<code class="prettyprint">...</code>

По функциональности Go-ogle Сode Prettifier "однобок": кроме подсветки синтаксиса, ничего предложить не может. Этот скрипт поддерживает PHP, HTML, Python, XML, Java, C, C++ и др. Демонстрационная страница с вариантами подсветки здесь: www.google-code-prettify.goog lecode.com/svn/trunk/tests/ prettify_test.html.

Напоследок - совет. Не злоупотребляйте скриптами. Изобилующие ими страницы долго открываются, медленно прокручиваются и у многих посетителей сайта вызывают раздражение. Да и вообще это дурной тон!

P.S.: Если вы используете нечто похожее на Syntax-Highlighter'а или Javascript code prettifier, сообщите, пожалуйста, на моем сайте в комментариях. Весьма интересно об этом узнать.

Илья Муравьев, ilyuha.org.ua

© компьютерная газета




Рубрика: Java Script




Инструменты Internet Explorer 8 Beta 2 для разработчиков.

Вебмастеру

В марте этого года мы уже писали об инструментах для разработчика в IE8 Beta 1, но IE8 Beta2 позволяет более полно использовать инструменты за счет значительных изменений в имеющихся функциях, а также новых возможностей. В принципе инструменты для разработчика должны обладать следующими свойствами: Быть интегрированными и простыми в использовании; Иметь визуальный интерфейсC их помощью можно быстро протестировать сайт.


Подробнее... | Рубрика: Вебмастеру | Добавлено: 05.09.2008

Google Developer Day 2008 в Москве.

Мероприятия

Дата проведения: 28 октября 2008 г.; Место проведения: Амбер Плаза, Москва, Россия. Конференция для веб-разработчиков и разработчиков мобильных приложений в Москве. Узнайте, как наилучшим образом использовать инструменты разработки и API от Google, чтобы создавать социальные, мобильные и картографические приложения, как использовать AJAX/JavaScript инструменты и библиотеки от Google и многое другое из первых уст.


Подробнее... | Рубрика: Мероприятия | Добавлено: 05.09.2008

ТОП 10 самых раздражающих факторов для программиста.

Разное

Совсем недавно наткнулся в интернете на забавный "хит-парад" наиболее раздражающих вещей для программиста. Поскольку он был на английском — решил перевести текст и несколько адаптировать к нашим реалиям…


Подробнее... | Рубрика: Разное | Добавлено: 03.09.2008

Остальные статьи:

Windows Server 7, 8 и 9
jQuery для JavaScript-программистов
Инновационный веб-броузер Google Chrome стартует уже сегодня
Windows 7: подход к производительности системы
Trac + Subversion @ Ubuntu: Revisited
[g]Vim в режиме Python: Рекомпиляция в Windows
Java + JSON. Пути к дружбе
Драйвер SQL Server 2005 для PHP
Типы данных в MySQL (сжатый справочник для PHP программиста)
PHP класс для работы с Яндекс.XML
Ошибки начинающих PHP разработчиков
Наследование шаблонов в Smarty
Особенности хранения сессий PHP в memcached
Internet Explorer 8 beta 2
9 правил для начинающего Ajax-разработчика
ExtJS 2.2 - полная поддержка Firefox 3, новые виджеты и другие нововведения


Цитата дня (все,добавить):



    Рубрикатор

Программирование

C/С++
Обучение
Windows API
XAML
Моделирование
Паттерны
Visual Basic 7 .NET
WxWidgets
Функции WinApi
Функции С++
Разработка под Mac OS
Eiffel
Visual Studio 2008
UI дизайн
Алгоритмы
Конкурсные статьи
Turbo Pascal
Visual Studio
CASE-средства
Visual Studio 2005
Без VCL
Delphi
Тех. документация
Тестирование
Software Testing
ООП
TCP/IP
Google Android
Windows Installer
.NET Framework
Драйвера
C# C Sharp
Справка
Проектирование
Информ. системы
Visual Basic
Assembler
Оптимизация кода
Gtk+
Компоненты
Реинжиниринг
Управление проектами
Extreeme programming
Lotus Notes
Алгебраическое проектирование

Интернет технологии

PHP
Perl
ASP
WAP
Cookies
SSI
CGI
Web Servers
VB Script
DNS
CSS
XML
Html
Java Script
Java2ME
Firewall
Flash
.htaccess
Apache
VRML
Протоколы
Поисковые системы
Технология JAVA
Учебник по PHP
Учебник по JavaScript
Учебник по XML
Java Q&A
AJAX
DHTML
XHTML
Dreamweaver
Web 2.0
Python
Вебмастеру
Cisco
Ruby on Rails
Silverlight

Базы данных

Access
InterBase
MySQL
Oracle
ADO .NET
Основы SQL
Учебник по Access 2002
MS
Microsoft FoxPro
Доступ к данным
XML в MS SQL Server 2000
ODBC и MyODBC
Обучение
Caché
DB2
PostgresSQL
Sybase
Теория
Хранилища данных
Безопасность
Реляционные данные
MySQL и mSQL

Остальное:

Разное
Обзоры книг
Безопасность
Графика и дизайн
Юмор
Linux
Фракталы
Microsoft Axapta
Многоядерность
Сети
Microsoft Office
Работа
MS-DOS
Криптография
Графика и игроделание
Новости SDK
Системы защиты
Учебник по AutoCad
CVS
Windows XP
Windows Server 2003
Windows Vista
Windows 7
Мероприятия

    Кто на сайте
Вы не зарегистрированы.
Имя:

Пароль:

Запомнить

Регистрация позволит Вам пользоваться дополнительными сервисами.
Сейчас на сайте:
Гостей: 80
Пользователей: 0