(95)Wangdao.com_第二十八天_进度事件

进度事件

进度事件 用来描述资源加载的进度,

主要由 AJAX 请求、<img><audio><video><style><link>等外部资源的加载触发

注意,除了资源下载文件上传也存在以下事件

  • abort        外部资源中止加载时(比如用户取消)触发。        如果发生错误导致中止,不会触发该事件。
    error        由于错误导致外部资源无法加载时触发。        有一个特殊的性质,就是不会冒泡。所以,子元素的error事件,不会触发父元素的error事件监听函数
    load        外部资源加载成功时触发。
    loadstart        外部资源开始加载时触发。
    loadend        外部资源停止加载时触发,发生顺序排在error、abort、load等事件的后面。
    progress        外部资源加载过程中不断触发。
    timeout        加载超时时触发。

  • 实例
  • image.addEventListener('load', function (event) {
        image.classList.add('finished');
    });
    
    image.addEventListener('error', function (event) {
        image.style.display = 'none';
    });

 

  • 浏览器原生提供了 ProgressEvent() 构造函数,用来生成事件实例
  • var progress = new ProgressEvent(type, options)
  • 第一个参数 是字符串,表示事件的类型,这个参数是必须的。
  • 第二个参数是一个配置对象,表示事件的属性,该参数可选。

配置对象除了可以使用 Event 接口的配置属性,还可以使用下面的属性,所有这些属性都是可选的

  • lengthComputable 布尔值        表示加载的总量是否可以计算,默认是false。
    loaded 整数        表示已经加载的量,默认是0。
    total 整数         表示需要加载的总量,默认是0

  • ProgressEvent 具有对应的实例属性

event.lengthComputable

如果event.lengthComputable 为 false,event.total 实际上是没有意义的

event.loaded

1

event.total        

 

  • 2
  • var p = new ProgressEvent('load', {
        lengthComputable: true,
        loaded: 30,
        total: 100,
    });
    
    document.body.addEventListener('load', function (e) {
        console.log('已经加载:' + (e.loaded / e.total) * 100 + '%');
    });
    
    document.body.dispatchEvent(p);
    // 已经加载:30%
  • 下载过程 实例
  • var xhr = new XMLHttpRequest();
    
    xhr.addEventListener('progress', function updateProgress(e) {
        if (e.lengthComputable) {
            var percentComplete = e.loaded / e.total;
        }else{
            console.log('不能计算进度');
        }
    }, false);
    
    xhr.addEventListener('load', function transferComplete(e) {
        console.log('传输结束');
    }, false);
    
    xhr.addEventListener('error', function transferFailed(evt) {
        console.log('传输过程中发生错误');
    }, false);
    
    xhr.addEventListener('abort', function transferCanceled(evt) {
        console.log('用户取消了传输');
    }, false);
    
    xhr.open();
  • 上传过程实例
  • var xhr = new XMLHttpRequest();
    
    xhr.upload.addEventListener('progress', updateProgress, false);
    xhr.upload.addEventListener('load', transferComplete, false);
    xhr.upload.addEventListener('error', transferFailed, false);
    xhr.upload.addEventListener('abort', transferCanceled, false);
    
    xhr.open();

 

转载于:https://www.cnblogs.com/tianxiaxuange/p/10105405.html

根据引用和引用中提供的信息,问题出现在launch.json文件中的"program"字段。该字段指定了要运行的程序路径。根据错误提示,程序路径应为'c\Users\18033\Desktop\VSCODE\build\Debug\outDebug',但该路径不存在。 为了解决这个问题,你可以按照以下步骤进行操作: 1. 确认你的程序编译后的可执行文件是否存在于指定的路径中。请检查路径'c\Users\18033\Desktop\VSCODE\build\Debug\outDebug'是否正确,如果不正确,请将路径修改为正确的位置。 2. 如果可执行文件存在于其他位置,请将路径修改为正确的位置。根据引用中的提示,你可以将路径修改为类似于'c:/HIT/WangDao/DS/output/${fileBasenameNoExtension}.exe'的形式。这将根据文件名自动生成正确的路径。 3. 确保路径中的斜杠符号是否正确。在引用中提供的示例中,斜杠符号是反斜杠(\)。如果你在路径中使用正斜杠(/),请将其修改为反斜杠。 4. 保存并关闭launch.json文件后,重新运行程序。确保路径已正确设置并且程序可执行文件存在于指定的位置。 综上所述,你可以通过检查程序路径是否正确,并根据需要进行修改来解决问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [launch: program ‘c: \build\Debug\outDebug’does not exist问题成功解决](https://blog.csdn.net/m0_55957625/article/details/130466016)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值