页面加载后发生的jQuery.get函数(HAML)

2022-04-17 00:00:00 jquery javascript html haml

所以我使用HAML并循环通过一组URL[url1、url2、url3],以便从其页面中提取图像并将其src放入另一个页面。我的代码如下:

urls.each do |url|
   .img{:id => "url_#{url}"}
   :javascript
        var urlID = "#url_" + "#{url}";
        $.get('#{url}').then(function(res){
              var src = $(res).find('.image').attr('src');
              // console.log(urlID);
              $(`{urlID}`).attr('src', src);
            });
然而,这似乎并不像每当我在$.get函数中使用sole.log(UrlID)时,它只会记录最后一个url 3次,而不是url1 url2 url3,我真的不确定为什么?这意味着它替换相同的图像源3次,而不是在每个图像类中显示3个单独的图像。有人知道为什么吗?


解决方案

将其包装在IIFE中以创建闭包并防止在请求完成之前覆盖该变量。

$.get()是异步的,因此您会多次创建相同的变量并覆盖前面的版本。当请求完成时,它将使用最后一个值

(function(){
    // only scoped in this IIFE closure and
    // not affected by other versions in your loop
    let urlID = "#url_" + "#{url}";
    $.get('#{url}').then(function(res){
          var src = $(res).find('.image').attr('src');
          // console.log(urlID);
          $(`{urlID}`).attr('src', src);
     });

})();

相关文章