html页中加入数学公式,Html+Css+JavaScript实现网页公式编辑器(一)

最近一直在做网页版的公式编辑器,现在进度过半,我来总结一下这段时间开发网页公式编辑器的经验。

开始开发之前,我在网上搜集了大量网页公式方面的资料,现在比较流行的网页公式都是用MathML:数学置标语言(Mathematical Markup Language,MathML),是一种基于XML的标准,用来在互联网上书写数学符号和公式的置标语言。JsMath:是一种在网页中显示数学公式的方法,通过解析 TeX 代码,结合 JavaScript 和 CSS 以及 unicode 字体 来显示数学公式,支持多浏览器和平台,无需 MathML 支持。诸如此类的技术还有,在此就不一一列举。

经过分析这些公式方法,发现他们各有优缺点,譬如有的方法最后公式生成为一张图片,虽然图片不大可以忽略网络传输的压力,但是一张数学试卷上面得有多少这样的小图片,而且修改也不方便。虽然有的方法可以加载一个第三方的CSS来达到网页显示编辑的目的,但是跨浏览器的表现也不尽如人意。有的还需要安装插件才能正常显示。

Html+Css+ JavaScript实现非图片的、在线网页编辑器理念应运而生。这样实现的网页编辑器屏蔽的图片实现的缺点,方便修改。于是,便开始分析《运筹学》此书中用到的公式以及特点。

以下摘取同事在开发公式编辑器的时候的总结:“公式输入或者书写,都是由左向右由下向上的。整体结构在阅读时也是遵循这样的规律的。.但是对于特殊的字符还要区分手写和大写,在公式前面可能会有属性限定例如:Max Min …虽然不涉及运算但是不能缺少的一个前缀。不同运算符各个项的比例不一样。括号输入的同时也需要独立一个项可以在括号外附加上下标。.为了不影响输入希望有插入设定能不在对整体改动的情况下对细节进行修改,方便输入答案的时候不因为修改细节而影响过多时间。”

吸取这位仁兄的总结,以及项目经理的建议,我把数学公式中分数、几次方、根号、积分等方法归为一个。

99633839_1.jpg

如图这九个方块就可以满足大部分的公式要求。我们把1号位置,叫做操作符,公式方法根据1号位置的符号来进行位置移动。例如:分数,1号位置为分数线,2号位置为分子,4号位置为分母。这样分数的大致形态就出来了,然后在进行位置的微调便可达到。积分:1号位置为积分符号,3、6、7分别为数值,这样实现了积分。

99633839_2.jpg

99633839_3.jpg

在html中,我们选用了span来表示方块。我们参考了MathML中的语法:

如:MathML中显示一个

99633839_4.png的代码如下:

99633839_5.gif

1

2

3 x

4 =

5

6

7

8 -

9 b

10

11 ±

12

13

14

15 b

16 2

17

18 -

19

20 4

21 ⁢

22 a

23 ⁢

24 c

25

26

27

28

29

30 2

31 ⁢

32 a

33

34

35

36

99633839_5.gif

我们实现刚才那个分数和积分的代码如下:

99633839_5.gif

1 分数:2

3   

4   2

5   4

6

7

8 积分:9

10   

11   3

12   6

13   7

14

99633839_5.gif

由此可以发现,我们的html代码十分简洁,只有开头span中表示它是一个数学公式和它是一个什么公式,浏览器便可以识别出它来。

下面是这两个方法在浏览器中的样子(比例有所放大):

99633839_6.png

99633839_7.png

分别在IE8,Chrome19,Safari5.1.7测试…

今天稀里糊涂说了一大堆,各位看官可能发现最重点的JS实现没有说出来,说实话,鄙人的JS知识浅薄,需要整理一下思路,欲知后文如何,各位看官且听下回分解...

PS:自己看了一遍,发现这一篇废话连篇,就是一个设计思路,重点如何实现思路大体说出来了,但是在具体一些还未涉及,后面如何写还有待深思熟虑啊...小生今年刚刚毕业参加工作,是一个90后的程序员,还需要前辈们多多拍砖啊...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值