CRM WebClient UI的浏览器打印实现

WebClient UI上自带了一个打印按钮,按Ctrl + P后能够生成一个新的页面供打印。javascript

以下图所示。能够看到这个页面里全部的超连接都已经被移除了。html

这个页面的生成逻辑以下。java

1. 按住ctrl + p以后,会触发WebClient UI框架的按键响应函数thtmlbKeyDown。浏览器传入的事件处理对象里ctrl属性为true,keycode为80(按键p对应的code),意思就是ctrl和p同时按下。浏览器

这个响应函数thtmlbKeyDown被注册到整个document对象上,所以您在页面任何位置点击ctrl+p都能获得响应。框架

从右上角的调用栈能发现crmFrwPrint被调用。crmFrwPrint会打开print.do这个控制器,位于BSP应用bspwd_basics里。函数

2. 打开print.do控制器的实现类CL_BSPWD_BASICS_PRINTcode

这个控制器会打开print.html页面htm

3. 咱们按了ctrl+p后生成的页面的内容就是在print.html里生成的。核心代码在函数ppStartScripts里,被thtmlbRegisterOnLoad注册到页面的load事件里,意思是print.html加载时就执行。对象

thtmlUtil.addEventHandler就是SAP本身封装的事件注册函数,用于多浏览器的兼容支持。blog

最核心的两个函数:

CreateShield

生成一个height和width为100%的div,背景图片设置成SAP预约义好的1x1.gif。

运行时显示以下:

loadPage

经过window.opener拿到发生了ctrl+p按键的原始页面,而后把其th-l-wcsubheadercontainer下面的全部元素的html直接复制到打印输出页面的header元素下面。

这样就实现了把原始页面的内容搬到了打印输出页面。

而后获得打印页面全部超连接标签,而后把这些标签的href和onclick都置为一个函数体为return false的函数,这样超连接就再也不能点击。

var nirvana = new Function ( "return false;" );

要获取更多Jerry的原创技术文章,请关注公众号"汪子熙"或者扫描下面二维码:

相关文章
相关标签/搜索