JavaScript 之 浏览器异步加载

当我们刚学js的时候,应该就知道js是单线程,进行的是同步加载,会阻断 html 和 css 的加载线(因为js能够修改 html 和 css)

js同步加载的缺点:加载工具方法没必要阻塞文档,过得js加载会影响页面效率,一旦网速不好,那么 整个网站将等待js加载而不进行后续的渲染等工作。

js里面有些工具方法需要按需加载,用到加载,不用不加载???这时候就需要我们异步加载js。

JavaScript异步加载的三种方案。

1、defer异步加载,但要等到dom文档全部解析完才会被执行。只有IE能用,也可以将代码全部写到内部

 <script type = "text/javascript" src = "tools.js"  defer = "defer"></script>
<script defer = "defer">
console.log("a");
</script>

2、async 异步加载,加载完就执行,async只能加载外部脚本,不能把js写在script标签里

 <script type = "text/javascript" aysnc = "aysnc"></script>

以上两种方法执行时也不阻塞页面

为了解决浏览器兼容问题??如果1,2,两种方法同时加载,会导致代码重叠覆盖执行顺序的冲突,所以引入第三种方法 通用的方法

3、创建script,插入到DOM中,加载完毕后callBack,

​
 var script = document.createElement('script');
 script.type = "text/javescript";
 script.src = "demo.js";
// 此时就会加载src地址里面的东西
// 此时会有一个灯塔模式,灯塔模式会产生一个img属性,用来存放地址的加载
document.head.appendChild(script);  //----此时就会在页面上展示js里面的内容

​

当我们在外部js文件里面写一个test函数

var script = document.createElement('script');
script.type = "text/javascript";
script.src = "demo.js";
test();
document.head.appendChild(script);

这里外部demo.js文件就不展示了,里面有一个test函数。结果如下:

test函数执行的时候因为加载需要时间,当test执行时,还没加载完。所以会显示test未定义。我们改如何解决这个问题呢?

首先我们就会想到onload事件。

script.onload      :         兼容性特别好,Safari chrome firefox opera都兼容 ;

 script.onload = function(){
                                test();
                            }

但是呢 IE 就script没有onload事件,IE人家有自己的方法:script.readyState。

script.readyState   :      IE 的script上面有个状态码(readyState),通过状态码的校验来判断是否加载完毕。在IE里script标签有个readyStatechange事件,这个事件监听的是,当script.readyState值变化的时候触发事件。

(script.readyState == "complete" || script.readyState =="loaded"  表示解析完毕。)

script.onreadystatechange = function(){
      if(script.readyState == "complete" || script.readyState == "loaded"){
                  callback(); //回调函数:当满足一定条件才可以被执行
              }
                  }

 最后我们封装函数,实现我们按需加载的功能。

 function loadScript(url,callback){
                        var script = document.createElement('script');
                        script.type = "text/javascript";
                        if(script.readyState){
                            script.onreadyStatechange = function(){
                                if (script.readyState == "loaded" || script.readyState == "complete") {
                                    obj[callback]();
                                }
                            }    
                        }else{
                            script.onload = function(){
                                obj[callback]();
                            }
                        }
                        script.src = url;
                        document.head.appendChild(script);
                    }

                    loadScript('demo.js','test');

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要模拟浏览器中的异步,您可以使用 Selenium 的等待机制和操作来模拟用户的行为。以下是一些常用的方法: 1. 使用等待机制:在页面过程中,使用隐式等待或显式等待来等待异步内容完成。可以使用 `driver.implicitly_wait(time)` 方法设置隐式等待时间,或使用 `WebDriverWait` 类和 `expected_conditions` 模块设置显式等待条件。 2. 模拟滚动页面:使用 `execute_script()` 方法来执行 JavaScript 代码,通过滚动页面的方式触发异步内容的。例如,可以使用以下代码向下滚动页面: ```python driver.execute_script("window.scrollTo(0, document.body.scrollHeight);") ``` 3. 模拟点击按钮:如果异步内容是通过点击按钮或链接触发的,可以使用 `click()` 方法来模拟点击操作。例如,可以使用以下代码点击一个具有特定 ID 的按钮: ```python button = driver.find_element_by_id("myButton") button.click() ``` 4. 使用 `ActionChains` 类:`ActionChains` 类提供了一系列的方法来模拟用户的复杂操作,例如鼠标移动、拖拽等。您可以使用它来模拟用户与页面交互的行为,从而触发异步。 ```python from selenium.webdriver import ActionChains element = driver.find_element_by_id("myElement") actions = ActionChains(driver) actions.move_to_element(element).perform() ``` 请根据具体的情况选择适合的方法来模拟浏览器中的异步。通过模拟用户的行为,您可以触发异步内容的,并获取到完整的网页内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值