【问题标题】:HTML/JS Check for external async file generationHTML/JS 检查外部异步文件生成
【发布时间】:2019-01-03 06:03:06
【问题描述】:

我想在 HTML/js 应用程序中显示由第三方应用程序生成的 svg。我遇到的问题是 svg 生成是异步的,当 HTML 尝试加载 svg 时,文件可能丢失(当时未写入)或不完整(正在写入)。 我查看了 Promise,但无法获得任何检查外部文件可用性的示例。 有什么想法吗?

【问题讨论】:

  • 到目前为止,您(确切地)如何访问该文件?
  • 我从 html 调用外部命令。完成后,我通过 JQuery 使用外部 svg url 更新 img src 属性。我需要设置一个时间间隔以确保外部文件正常。

标签: javascript html svg promise fs


【解决方案1】:

由于您在 cmets 中提到,您可以通过外部 url 访问 svg:

你可以用 JavaScript/Jquery 检查外部文件是否存在(只要你可以通过 http 访问)

因此,您可以进行这样的检查。如果找到文件,则更新图像 src,如果没有,请稍后重试:

这是一个小例子:

//example retry delay of 3 seconds
var delay = 3000;
var url = "http://www.doma.in/path/yourimg.svg";

function tryUpdate(){
    $.get(url)
        .done(function() { 
            //your picture exists
            updateImgSrc();
        }).fail(function() { 
            // picture doesn't exist yet -> retry after time
            setTimeout(tryUpdate, delay);
        })
}

【讨论】:

    猜你喜欢
    • 2021-05-26
    • 1970-01-01
    • 2020-12-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-03-16
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多