广告等第三方应用嵌入到web页面方案 之 使用js片段

广告等第三方应用嵌入到web页面方案 之 使用js片段

在自己的项目中嵌入过广告的朋友们可能都用过百度联盟, 只需要嵌入如下一段js代码片段, 就可以在自己的项目中嵌入广告, 来获得收益.

1

2

3

4

<script type=“text javascript”>

   var cpro_id = “u2557752”;

</script>

<script src=“http://cpro.baidustatic.com/cpro/ui/cm.js?id='i9898'” type=“text/javascript”></script>

 本文就是主要介绍如何通过嵌入js片段的方式来嵌入广告等第三方的应用的, 具体的实现方案有两种:

在服务端生成脚本:

  服务端接收到请求后, 从url中提取到参数, 再根据参数从数据库中查找出对应的数据信息,比如是广告的话, 就查找到对应的广告素材, 并将查询到的数据信息插到javascript模板中,

浏览器执行js脚本代码,创建出广告

直接引入静态js脚本:

首先js文件中提取到参数,根据参数向服务端发起请求, 获取到对应的数据, 再通过js创建html片段,输出到页面上

两种方案对比: 

  服务端生成脚本,所有的代码和数据都包含在生成的js文件中,不需要做额外的请求,适用于内容及样式相对简单的页面.比如只有一个图片的广告展示.

对于内容较多,样式较为复杂的内容展示通过第二种方案实现更加灵活.

两种方案实现起来, 主要以下几步: 

1.获取参数 --> 2.获取数据 --> 3.输出html

1.传递参数

下面介绍一下脚本参数传递的几种方式的优缺点:

  1.通过拼接URL传递

1

<script src=“http://cpro.baidustatic.com/cpro/ui/cm.js?cpro_id=u2557752” type=“text/javascript”></script>

  优点: 可通过URL传递到服务器

  缺点: 必须进行DOM查询,无法缓存

  2.通过hash传递

1

<script src=“http://cpro.baidustatic.com/cpro/ui/cm.js#cpro_id=u2557752” type=“text/javascript”></script>

  优点: 使用URL,便于缓存

  缺点:  必须进行DOM查询

  3.自定义属性

1

<script data-hxh-coupon-id=‘1234’ src=“http://cpro.baidustatic.com/cpro/ui/cm.js type=“text/javascript”></script>

  优点: 可读性强, 便于缓存, 易于识别脚本引入代码的位置

  缺点:  必须进行DOM查询

  4.使用全局变量

1

2

3

4

<script type=“text/javascript”>

  var couponId = ‘87393’;

</script>

<script src=“http://cpro.baidustatic.com/cpro/ui/cm.js type=“text/javascript”></script>

  优点: 可读性强,便于缓存,参数类型灵活,无需进行DOM查询

  缺点: 使用了全局变量

2.获取数据

关于获取数据, 服务端生成脚本, 服务端直接查询数据, 静态js脚本方案中, 可使用jsonP, Cors等方案进行跨域请求.

3.输出html

  • 1.使用document.write

  document.write直接在当前文档流中写入字符串,一旦文档流已经关闭,就打开新的文档流并写入,原来的文档流会被清空,已渲染好的页面就会被清除,浏览器将重新构建DOM并渲染页面.所以使用这种方案, 就一必须是同步执行嵌入的这段js代码, 作为第三方脚本引入,阻塞性的脚本会阻止主页面的渲染,如果js文件加载迟缓,甚至不可用的, 会给主页面造成严重的性能问题, 所有不建议使用.

  •  2.操作DOM添加

  1.在目标位置嵌入js片段, 并使用预先定义的ID,class,data-*等(如上)

  2.js文件中创建DOM元素,将HTML字符串赋值给元素的innerHTML属性

  3.根据ID,calss,data-*等查询到脚本所在位置,并将元素添加到DOM中 

1

2

3

4

5

6

7

8

9

<script id='hxh-coupon-scandown' type="text/javascript">

    (function(){

        var script = document.createElement('script');

        script.async = true;

        script.src = 'http://www.boxmars.com?id=123';

        var entry = document.getElementsByTagName('script')[0];

        entry.parentNode.insertBefore(script, entry);

    })()

</script>

  优点: 

    1.可以异步加载第三方DOM, 不阻塞主页面的渲染,即使js出错,也不会影响到主页面

    2.可以将创建的DOM动态插入到已存在的元素之后(即可以追加到已知位置) 

  缺点:

    1.使用字符串拼接不利于HTML片段的编写和维护

    2.会继承父页面样式

    3.主页面可更改DOM内容

  字符串拼接不利于编写和维护的问题,可以通过JavaScript模板引擎库来编写HTML片段, 流行模板库:HandlebarsJS,Mustache,BAIDU-Template,artTemplate等

  • 使用不设置src的iframe

  主页面提供一个不设置src的iframe标签,通过iframe的contentWindow访问iframe的DOM,使用document.write将HTML直接写入到iframe中

1

2

3

4

5

6

7

8

var doc = document.getElementsByTagName('iframe')[0].contentWindow.document;

doc.writeln("<button id=\'btn\'>点击</button>");

doc.writeln("<script type=\'text/javascript\'>");

doc.writeln("var btn = document.getElementById(\'btn\');");

doc.writeln("btn.onclick = function(){");

doc.writeln("parent.parentEvent();");

doc.writeln("</script>");

doc.close(); 

  注: iframe由浏览器异步处理, 所以此处使用document.write()并不会阻止父页面的加载

优点: 

  1.完全独立的DOM环境,不会继承父页面的样式

  2完全独立的window,避免和主页面其他脚本冲突

  3.可直接与主页面进行交互(与iframe引入外部页面对比)

缺点: 

  1. Iframe标签的创建速度慢

  2.主页面可以访问iframe的DOM环境并可进行更改

 

 嵌入第三方页面两种方案中,另一种方案(http://www.cnblogs.com/yuqing6/p/8462239.html) 都大篇幅介绍使用了iframe进行html输出,iframe提供了一种最佳的避免样式和脚本冲突的嵌入途径,但是有些情况在主页面的DOM中去渲染更为合适

不适合使用iframe的情况: 

  1.需要在iframe外部呈现内容, 场景: 第三方应用中需要弹出对话框时,如果iframe不是覆盖整个页面的, 就无法正常展示对话框 

  2.一个页面引入很多个iframe嵌入页面, 同一个页面引入许多个iframe时, 会带来主页面很大的性能开销, 对于只是渲染一两次情况, 这种性能消耗可以忽略不计

  3.需要继承父页面的基础样式, 有些时候,希望第三方应用继承父页面的基础样式, 来和主页面的样式风格保持一致,这种情况不适用于使用iframe

 

转自’https://www.cnblogs.com/yuqing6/p/8467177.html?utm_source=debugrun&utm_medium=referral

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在使用Qt开发桌面应用程序时,我们可能会遇到需要将第三方应用程序嵌入到我们的程序中的情况,这时就需要进行一些相关的配置和操作。常见的第三方应用程序包括浏览器、视频播放器、PDF阅读器等。 一般来说,我们可以使用Qt的QProcess类来启动第三方应用程序,然后将其嵌入到我们的程序中。同时,为了实现良好的用户体验,我们还需要对嵌入应用程序进行一些界面以及交互上的调整和配置。 需要注意的是,嵌入第三方应用程序可能会带来性能和安全上的方面问题,因此在进行操作时需要格外小心并进行充分的测试。此外,对于某些操作系统和平台,可能会存在一些限制或者需要特殊的配置和处理方式,这也需要我们进行深入的研究和了解。 总之,Qt提供了丰富的API和工具,使得我们可以比较容易地实现第三方应用程序的嵌入和定制化。在具体实现过程中,需要根据具体情况进行合理的配置和调整,以实现最佳的效果和用户体验。 ### 回答2: 在Qt中,嵌入第三方应用exe可以通过QProcess类来实现。首先,需要创建一个QProcess对象,并使用它来执行要嵌入第三方应用exe。其次,需要显示第三方应用的窗口,并将其添加到Qt应用程序的窗体中。这可以使用QWidget的QWidget::createWindowContainer()方法来实现,该方法可以将一个QWidget作为另一个QWidget的子控件,并将其嵌入到其父QWidget中。最后,需要将第三方应用的输入和输出与QProcess对象的输入和输出进行连接,以便能够与其进行交互。 但是需要注意的是,Qt应用程序和第三方应用的所使用的共享库必须是兼容的,否则可能会导致崩溃或者其他问题。此外,也可能会遇到中文乱码等问题,需要根据实际情况进行处理。 ### 回答3: Qt 是一个跨平台的应用程序开发框架,可以轻松地开发各种类型的应用程序,包括图形用户界面应用嵌入式软件、网络应用、数据库应用和游戏等。在 Qt 中,开发者可以通过使用 QProcess 类,来启动和控制外部应用程序,包括第三方应用程序。对于需要嵌入第三方应用程序的情况,一般需要借助使用一些特殊的工具和技术来实现。 在嵌入第三方应用程序到 Qt 应用程序中时,需要将第三方应用程序打包成 DLL 或者直接生成可执行文件。在 Qt 应用程序中,可以使用 QLibrary 类来加载和调用 DLL 并完成嵌入。如果第三方应用程序是一个可执行文件,需要在 Qt 应用程序中使用 QProcess 类启动该应用程序,并设置相关参数、环境变量和路径等信息。启动后,需要使用 QWidget 的子类来创建一个嵌入窗口,并使用 QWinWidget 类将嵌入窗口与 QProcess 类中启动的应用程序进行连接,使第三方应用程序可以显示在 Qt 程序中的指定区域,并接收输入事件和操作。 在使用 Qt 嵌入第三方应用程序时,需要注意一些问题,如应用程序的兼容性、界面的集成、窗口之间的交互等。同时,还需要考虑到不同平台之间的差异性,例如 Windows 和 Linux 系统下嵌入第三方应用程序的方法和实现方式可能会有所不同。因此,在实际开发中,根据具体情况,需要采用适当的技术和工具来实现嵌入第三方应用程序的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值