在博客里轻松使用LaTeX 数学公式[转]

 

笔者最近的博文有不少数学相关内容,发现利用一些网上服务、jQuery和CSS,可以更轻松地在博客里使用语法排版方程式。是基于的排版系统。而就是美国著明计算机教授高德纳(Donald E. Knuth),为了编写他的巨著《计算机程序设计艺术(The Art of Computer Programming)》而设计的系统,对于数学公式的排版支援十分强大。

线上LaTeX数学公式编辑器

笔者最初使用这个线上LaTeX数学公式编辑器,输入公式时,就会产生一个影像档案(如GIF、PNG、SVG),把该HTML代码复制到博客即可。例如:

view sourceprint?
1\sqrt{a^2+b^2}

选择输出为HTML,该编辑器就会产生以下的HTML代码:

view sourceprint?
1<img src="http://latex.codecogs.com/gif.latex?\sqrt{a^2+b^2}" title="\sqrt{a^2+b^2}" />

这HTML码就能显示该公式

这个方法已算不错了,但还有3个小问题:

  1. 每次修改,都要从IMG找到代码,复制过去编辑器,再复制过来,比较麻烦。
  2. 希望像一般技术书籍,为公式加入编号,方便评论和沟通时使用。
  3. 万一想改变生成影象的服务、输出格式、大小设置等,就要修改每个地方。

于是,笔者想到使用jQuery,把放置代码的特定的HTML标记,自动变换成IMG标记,并使用CSS作编号。

jQuery作转换

笔者最近才得知jQuery,是百分百新手,请各位不吝赐教。

现时希望支持两种数学公式,一种是文字中的内联(inline)公式,另一种是整行独占的公式。笔者分別采用span和div标记,并共同使用math作为class:

view sourceprint?
1<span class="math">latex code</span>
2<div class="math">latex code</div>

之后,就使用以下JavaScript代码,在网页载入后做这个转换:

view sourceprint?
1// math.js
2$(document).ready(function() {
3    $(".math").each(function(i) { $(this).html("<img src=\"http://latex.codecogs.com/png.latex?" + this.innerHTML + "\"/>"); });
4});

CSS排版

最后,利用CSS2计数器(CSS2 counter),为非内联的公式加入编号。 编号的方式各有喜好,笔者博客里使用采用(节.公式编号)格式,笔者定义"节"(section)是以<h2>为层级,公式编号则是在一个章节里从1开始。在博客园中,博客内文是在div.entry之内,以下CSS代码就能为公式加上编号和置中(可加进博客"修改设置 -> 通过CSS定制页面风格"):

view sourceprint?
1body { counter-reset:section 0; }
2div.entry h2:before { counter-increment:section; content: counter(section) ". " }
3div.entry h2 { counter-reset:equation }
4div.math:before { counter-increment:equation; content: "(" counter(section) "." counter(equation) ")"; float:right; }
5div.math img { display: block; margin-left:auto; margin-right:auto; }
6span.math img { border:none; vertical-align:middle; }

测试1

view sourceprint?
1<p>牛顿力学第三定理是</p>
2<div class="math">\vec{F}=m \frac{d \vec{v}}{dt} + \vec{v}\frac{dm}{dt}</div>
3<p>当中<span class="math">\frac{d \vec{v}}{dt}</span>是速度相对于时间的改变。 </p>
4<p>爱因斯坦的能质守衡公式是</p>
5<div class="math">E=mc^2</div>

牛顿力学第三定理是

当中是速度相对于时间的改变。

爱因斯坦的能质守衡公式是

(可看到方程计数器的递增,使编号由(4.1)变成(4.2)。)

测试2

view sourceprint?
1<p>计算两个矢量<span class="math">\mathbf{A}</span>和<span class="math">\mathbf{B}</span>之间的夹角<span class="math">\theta</span>,可用</p>
2<div class="math">\cos \theta = \frac{\mathbf{A} \cdot \mathbf{B}}{\left \| \mathbf{A} \right\| \cdot \left \| \mathbf{B} \right\|}</div>

计算两个矢量之间的夹角,可用

(可看到h2标记把计方程数器重置,使编号变成(5.1)。)

结语

对于简单的公式,笔者现在可以直接使用HTML编辑器输入代码,修改也容易。透过CSS把显示的格式和内容分离,将来改变皮肤、或影象生成服务等也变得容易。

一个缺点是,读者透过RSS等方式,只能看见源码。

读者可于这里下载代码。

关于的进阶公式输入方法,可参考中文维基:数学公式

 

来源:http://www.cnblogs.com/miloyip/archive/2010/04/26/1720877.html

转载于:https://www.cnblogs.com/guangrou/archive/2010/10/14/1851440.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/380864.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

oracle查看所有用户_Oracle实用命令查看共用一个表空间的所有用户

概述有朋友问到如何查出表空间都被哪些用户使用的一些方法&#xff0c;因为有几种情况需要考虑&#xff0c;也顺便做个总结。需求&#xff1a;如何查看共用一个表空间的所有用户查看某表空间下表的所有者使用dba用户查询&#xff1a;1、如果先要知道表空间的命名&#xff0c;可…

Hibernate中把Session和线程绑定的配置

我们一开始用session都用HibernateUtil工具类获得Session对象&#xff0c;因为该工具类可以保证将线程不安全的Session绑定到当前线程内&#xff0c;但每次返回的对象都是一个新的session&#xff0c;我写了一个测试方法如下&#xff1a; Testpublic void test() {Session s1 …

【转】小周立波张冯喜引爆达人秀 小童星家居照大曝光

原文地址&#xff1a;http://www.soufun.com/news/2010-10-13/3897753.html 小小年纪&#xff0c;一身西装&#xff0c;发式清爽&#xff0c;腔调十足&#xff0c;有观众说她“天才有余&#xff0c;天真不足”&#xff0c;她自己说“进演艺圈太累了”&#xff0c;刚踏进演艺圈就…

mysql命令教学_mysql常用命令有什么

mysql常用命令有&#xff1a;1、“create database name;”&#xff1b;2、“use databasename;”&#xff1b;3、“drop database name”&#xff1b;4、“show tables;”&#xff1b;5、“select version”等等。MySQL 数据库常用命令1、MySQL常用命令create database name; …

调整和改编赛车游戏——游戏屏幕

游戏屏幕 赛车游戏中有很多不同的游戏屏幕&#xff0c;这些都是由RacingGame类中的gameScreens堆栈管理的。本节介绍游戏中使用的大部分屏幕和对应的功能。大多数游戏屏幕相当简单&#xff0c;但其他的有点复杂并实现了一个单元测试&#xff0c;通过单元测试能更好地了解这个类…

trie树--详解

MiYu原创, 转帖请注明 : 转载自 ______________白白の屋 文章作者&#xff1a;yx_th000 文章来源&#xff1a;Cherish_yimi (http://www.cnblogs.com/cherish_yimi/) 转载请注明&#xff0c;谢谢合作。关键词&#xff1a;trie trie树 数据结构前几天学习了并查集和trie树&am…

yii mysql gii_Yii Gii使用

准备数据库第1步 - 创建一个新的数据库。数据库可以通过以下两种方式进行。在终端运行 mysql -u root –p登录数据后&#xff0c;通过执行 CREATE DATABASE mystudy CHARACTER SET utf8 COLLATE utf8_general_ci; 创建一个新的数据库;第2步 - 在 config/db.php 文件中配置数据库…

通过OracleDataReader来读取BLOB类型的数据 (转载)

通过OracleDataReader来读取BLOB类型的数据 在实际的应用过程中&#xff0c;需要把大块的二进制数据存储在数据库中。读取这些大块的数据&#xff0c;可以通过强制类型转换成为byte数组&#xff0c;但是当这个二进制数据体够大时&#xff08;几十兆或者上百兆&#xff09;&…

xampp启动Apache端口被占用,修改端口

apache启动端口被占用有可能是80端口被占用&#xff0c;也用可能是443端口被占用。修改这两个端口方法如下&#xff1a; 首先打开xampp&#xff0c;点击下图的config 如果是80端口被占用&#xff0c;选择httpd,conf,会自动打开这个文件&#xff0c;然后在文件里查找80 找到以…

Microsoft SharePoint Server 2010 的新增功能

Microsoft SharePoint Server 2010 包括几个关键的增强和新增功能。重新设计的用户界面中的功能区通过将命令放置到更易于导航的基于任务的选项卡上&#xff0c;来帮助您更快地完成工作。可以跨多个 Internet 浏览器工作&#xff0c;例如 Microsoft Internet Explorer 7.0 和 8…

php四种定界符

1.标准风格 <?php//代码 ?>2.短标记风格 <?//代码 ?>默认情况下是不可以这样写的&#xff0c;我们要到php.ini文件里修改一个配置 找到php.ini文件,我用的是xampp,所以就是以他为例&#xff0c;其他找到php.ini文件方法百度一下就知道了 点击Apache的config&…

php中文乱码问题

访问我的php文件&#xff0c;出现了乱码 解决方法如下&#xff1a; 方法1&#xff1a;加上meta标签&#xff0c;设置字符格式 例如&#xff1a; <?phpecho <meta charset"utf-8">;echo "小河流水人家"; ?>访问就不会乱码了&#xff0c;注…

java 文件转换字符串_java字符串文件互相转换

Java字符串与文件的互转Java中有时候需要读取一个文本类的文件,将其转换为字符串&#xff0c;然后做进一步处理。Java中没有现成的API方法&#xff0c;自己手动实现一个&#xff0c;大家来分享。一、字符串转换为文件/*** 将字符串写入指定文件(当指定的父路径中文件夹不存在时…

php中的echo、print,print_r、var_dump

我们用代码的运行结果来说明 1、echo <?phpheader(content-type:text/html;charsetutf-8);echo "小河流水人家",<br>;echo 10,<br>;echo true,<br>;echo false,<br>;echo array(8),<br>; ?>运行结果 可以输出字符串和数字…

风雨20年:我所积累的20条编程经验 (转)

风雨20年&#xff1a;我所积累的20条编程经验 (转) 编者按&#xff1a;原文作者乔纳森丹尼可&#xff08;Jonathan Danylko&#xff09;是一位自由职业的web架构师和程序员&#xff0c;编程经验已超过20年&#xff0c;涉足领域有电子商务、生物技术、房地产、医疗、保险和公用事…

php的变量、传值、传址、销毁变量

在php中&#xff0c;php的语句需要以**;**结尾&#xff0c;而且变量区分大小写&#xff0c;但关键字不区分大小写 1、变量的命名规则 变量必须以$开头&#xff0c;比如$name&#xff0c;$不是变量名的一部分&#xff0c;仅表示变量名的开始除了$以外&#xff0c;以字母、下划…

php的超全局变量

php的超全局变量如下图 所有的超全局变量都是数组类型&#xff0c;并且php已经帮我们定义好了&#xff0c;下面重点介绍几个 $_GET:用来保存get方式提交的数据 <!DOCTYPE html> <html><head><meta charset"UTF-8"><title>测试$_GET…

cmd运行php文件以及环境配置出现的问题、 php.exe不是内部或外部命令,也不是可运行的程序 或批处理文件、PHP startup: Unable to load dynamic library

我用php.exe远行php文件出现了几个问题&#xff0c;先说一下怎么解决这些问题的&#xff0c;然后再说怎么运行 首先是出现 ‘php.exe’ 不是内部或外部命令,也不是可运行的程序 或批处理文件&#xff0c;查了一下&#xff0c;是没有配置php环境变量&#xff0c;配置php环境的过…

php定义常量、判断有没有被定义、预定义常量、显示所有常量

常量一旦被定义&#xff0c;在脚本的其他任何地方都不能被改变&#xff0c;注意&#xff1a;常量名的前面没有$ 语法&#xff1a;define(name,value,case_insensitive ) name:常量名&#xff0c;一般常量名都大写value&#xff1a;常量值case_insensitive &#xff1a;bool类型…

java server模式 设置_JVM client模式和Server模式的区别

这里向大家描述一下JVM client模式和Server模式两者的区别和联系&#xff0c;JVM如果不显式指定是-Server模式还是-client模式&#xff0c;JVM能够根据下列原则进行自动判断(适用于Java5版本或者Java以上版本)。JVM client模式和Server模式JVM Server模式与client模式启动&…