# Webview及基础模块
上面在用小程序架构图的时候一直说渲染层、逻辑层。下面带大家来找一下这两个文件。
首先我们在微信开发者工具上默认看到的界面是调试我们开发代码的地方,真正渲染编译的文件并不是长这个样子的。比如说在调试器中看到的WXML选项卡中,看到的代码和我们项目中的WXML代码是一致的,这样的话我们很方便的就可以调试。
话不多说,我们在左上角选择,微信开发者工具 ->调试 ->调试微信开发者工具。

然后你会发现弹出了另一个调试界面,与谷歌的调试界面不能说相似吧,简直一摸一样。打开Element页签看到结构如下。这是微信开发者工具的结构。并不是渲染层。
可以看到微信开发者工具的界面的代码竟然如此熟悉,就是html。就像调试网页一样,鼠标滑过页面DOM结构的时候,微信开发者工具相应的模块就会高亮起来,可以简单看一下微信开发者工具的页面结构。不得不感叹一下混合开发这样的开发模式,不仅仅在移动端应用起来,在PC端也是完全没有问题的,性能用起来也是没什么问题的,能用javascript写的终究会用javascript来重写。大前端666.
我们在Element页签中的DOM结构中来找一找左侧我们看到页面的模块是怎样展现的呢。找到的话如下。

我们可以看到一些webview标签,其中第一个webview标签的src路径看起来是不是很眼熟,这个就是当前页面在项目中的路径,以webview的形式渲染在微信开发者工具界面中,可以说是嵌入在里面。
这个才是真正的渲染层,在这里是无法展开webview标签看到里面页面的具体结构的,要用一些特殊的方式。
在开发者工具调试界面,也就是单独的调试界面中切换到console页签,这里的console页签和我们平常使用的浏览器的是一样的。我们找到webview所有的DOM节点。

这里可以看到有四个webview,如果跳转页面了大于4个也是正常的,如果打开新页面,则会创建并插入一个新webview。我这里是只打开了默认页面,所以只有四个,下面我会演示大于4个点时候。基础的四个webview分别是什么呢?他们分别是视图层的webview,业务逻辑层webview,调试器的webview和编辑区的webview。重点分析视图层和业务逻辑层webview。

上方webview层src路径为pageframe/pages/index/index 是渲染层视图,渲染的就是我们进来时候开到的初始页面。 下方webview层src路径为appservice/appservice?*** 是逻辑层视图。
由上面可以看出,小程序开发者工具业务逻辑层是在webview中执行的。这里可能有人有些绕,这里举例子的一切环境都是我们电脑上的微信开发者工具。微信开发者工具模拟了在移动端的双线程结构。每个webview可以理解为在移动端跑的一条线程。
因为小程序开发者工具是HTML嵌入写的,所以看代码示例可能看着看着就以为是小程序了,缕清这一点,上面我们看到的HTML结构不是小程序,只其中几个webview中才是小程序的逻辑。其他的都是开发者工具为了模拟微信端的环境。

所以我们重点关注视图层和逻辑层的webview。
如果我们回到开发者工具的操作页面进行页面跳转一下。点击一下index页面的头像会跳转到logs日志页面后,回到开发者工具的devTools工具后再寻找webview层,这时候会发现多了一个webview

从图中可以看出,多了一个视图层webview:pages/logs/logs,可以见得,页面得载入是通过创建并插入webview来实现的,
这个过程中会涉及到一个问题,就是打开页面的数量。在某些设计下,比如一个商品详情页面中会推荐其他的商品,这些商品点进去就是详情页面。详情页面中又有推荐,又可以点进去。这样重复下去打开的页面就会越来越多。
如果不做限制,会有严重的内存问题。所以在这方面,微信小程序做了限制,在微信小程序中打开的页面不能超过10个,达到10个页面后,就不能再打开新的页面。这时候有可能会卡死,不知道的话会以为是bug。
我们话接上文,从上方我们自己寻找webview代码节点可以知道第一个就是page/index/index路径相对应的webview。通过showdevTools方法来打开调试此webview界面的调试器。命令如下。
document.getElementsByTagName('webview')[0].showDevTools(true, null)
上述命令复制粘贴的时候有时候打不开调试器,复制粘贴打不开的话,从头手打即可。打开的调试器页面如下:

是不是很多调试器一层套一层的。不过不必慌张,我们慢慢看下去,看到最后你一定会豁然开朗的。我们继续。
这样的话就打开了当前显示的页面的调试界面。可以看到这里的title显示的就是小程序渲染层。
我们看一下小程序渲染层的结构,从head区域开始分析,从上到下。
第一个style标签中包含了一些基础style标签。展开的部分截图如下:

第一个style标签处理了webview层的基础组件的样式初始化。
上面我们提到过wxml中的标签使用的是Exparser框架,其中这些自定义组件的样式也是需要一起渲染在webview中的。
可以看一下截图,黄色区域的base64两张图片我也贴在这里,是wx-audio-button标签的开始切图和暂停切图。

