简要的说,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
相关解决方案
- Android webkit image的加载进程解析
- webkit 设立body背景色为透明的方法
- Bug札记:webkit-appearance:none导致无法获取checkbox值
- webkit/opera中window[name]获取flash对象的非一般实现
- WebKit 内核源代码分析 ( 4 )
- android webkit JavaScript 不能处理onkeydown的下上左右键,引发的话题
- 关于x-webkit-speech 语音输入效能体验与小结
- Webkit-Cookies分析篇
- [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)
- android.view.InflateException Error inflating class android.webkit.WebView
- css3中属性前缀(-moz、-ms、-webkit、-o-)
- x-webkit-speech 输入框中添加“小话筒”
- 针对IOS的-webkit-appearance参数问题
- CSS3样式之 CSS3自定义滚动条样式 ::webkit-scrollbar
- -webkit-margin-before:1em;-webkit-margin-after:1em;-webkit-margin-start:0px;-webkit-margin-end:0px;
- 用meta name=renderer content=webkit|ie-comp|ie-stand来切换360双核安全浏览器的极速模式和兼容模式
- Webkit 网络加载到DOM树创建的堆栈记录
- h5页面与android(WebViewJavascriptBridge) / ios(window.webkit.messageHandlers)交互
- 话不多说, 以左上角为原点 -moz-transform-origin: 0 0; -webkit-transform-origin:0 0; -o-transform-origin:0
- Vivo 5.0手机:android.view.InflateException: Error inflating class android.webkit.WebView
- 每日一记:ie浏览器中CSS3 -webkit-transform(元素变换)不生效的解决方案
- CSS3属性-webkit-font-smoothing字体抗锯齿渲染