简要的说,WebKit由三个模块组成:JavaScriptCore、WebCore?和?WebKit。WebKit作为了整个项目的名称。 JavaScriptCore:是JavaScript解释器; WebCore:是整个项目的核心,用来实现render引擎:解析Web页面,生成一个DOM树和一个render树,并最终render it with a backend(后端?),当前已经有很多移植的Backend,如WebKit/GTK,WebKitQT等。在上图中,backend从WebCore中分离出来了,但实际上它是WebCore的一部分。 WebKit:它隐藏并选择WebCore到当前平台。在WebKit/Gtk中,WebCore以Gtk objects的形式出现,并且它们的signals和API类似其他的Gtk objects. 当前WebKit支持四种平台:GTK、QT、Mac OS X、和Cygwin。 GTK和QT使用qmake Mac OS X使用xcodebuild Cygwin则使用Visual Studio 下面主要针对Qt版的WebKit作分析介绍: 首先,执行WebKitTools/Scripts下的build-webkit Perl?脚本,可以使用一些参数配置需要的功能模块,主要有SVG的一些功能配置,以及XPATH、XSLT、VIDEO等。脚本执行过程中会对相应的参数进行解析,确定编译选项、功能模块、平台信息以及相应的工具、输出路径等等参数,最后根据不同的参数,使用qmake工具由webkit.pro生成整个工程的makefile。在make的过程中会进一步调用qmake由各个子模块的.pro项目文件生成各模块的makefile。最后make各个子模块的makefile就可以得到需要的目标文件。 这个project可以分成JavaScriptCore、WebCore、WebKit三个子模块,对应到三个子目录,具体的如上面WebKit结构介绍的。 ???????更进一步,整个project又分成了六个可构建出来的子project,对应到相应的.pro文件。 WebKit\WebCore\WebCore.pro:生成libQtWebKit.so或libQtWebKit.a,是整个WebKit引擎库,WebKit应用都是基于这个库。 WebKit\JavaScriptCore\kjs\testkjs.pro:生成testkjs可执行文件,它是一个JavaScript的测试工具,测试JavaScriptCore模块的功能实现。 WebKit\JavaScriptCore\pcre\dftables.pro:生成dftables可执行文件,也是一个工具。 WebKit\WebKit\qt\QtLauncher\QtLauncher.pro:生成QtLauncher可执行文件,它是基于WebKit的一个简单浏览器的应用。 WebKit\WebKit\qt\Plugins\plugins.pro:生成了libqtwebico.so,install后会放到/usr/lib/qt4/plugins/imageformats/下,这个库的作用还不明了,因为目前运行的QtLauncher应用没有用到它,有待研究。 WebKit\WebKitTools\DumpRenderTree\qt\DumpRenderTree.pro:生成DumpRenderTree工具,也是基于WebKit的一个应用工具。
WebKit工程组织与管理
平台与工具
工程结构
详细解决方案
WebKit构造
热度:351 发布时间:2012-12-24 10:43:13.0
1 楼
天宇孤鹰
2011-05-13
相关解决方案
- -moz- -webkit- -ms- 替神马要写全
- -webkit-text-size-adjust: none;该如何处理
- -webkit-transform: translate(0px, 0px) translateZ(0px);影响定位?解决方法
- Android webkit image的加载进程解析
- HTML5语音输入x-webkit-speech步骤 支持webkit内核
- webkit 设立body背景色为透明的方法
- -webkit-min-device-pixel-ratio的常见值对比
- Bug札记:webkit-appearance:none导致无法获取checkbox值
- webkit/opera中window[name]获取flash对象的非一般实现
- WebKit 内核源代码分析 ( 4 )
- Android WebKit 容易例子
- WebKit CSS3 卡通片基础
- android webkit JavaScript 不能处理onkeydown的下上左右键,引发的话题
- webkit 作图流程解析(2)
- Webkit内核探究【二】――Webkit CSS实现
- 关于x-webkit-speech 语音输入效能体验与小结
- (转)WebKit,鼠标挑动的故事
- Webkit-Cookies分析篇
- -webkit-内核滚动条式样覆盖
- [WebKit]RefPtr跟PassRefPtr基础[1]
- 引见一下x-webkit-speech -实现语音输入
- 为什么-webkit-transition-duration最高只有40帧?该如何解决
- -webkit-transform: translate(0px, 0px) translateZ(0px);影响定位?该如何处理
- qt webkit 无法浏览网页解决方案
- 求解 Qt4.7 webkit 支持 spice协议吗,该如何处理
- Qss -webkit-gradient背景图有关问题,大神看过来.
- qt webkit 光标响应有关问题
- 在nwjs中将数据从nodejs传递到angular的正确方法(node-webkit)
- vue中使用-webkit-line-clamp、-webkit-box-orient属性,项目打包后不生效?
- 手机横屏后字体变大 -webkit-text-size-adjust