gpt4 book ai didi

javascript - onError 在浏览器之间表现不同

转载 作者:行者123 更新时间:2023-11-28 13:30:49 27 4
gpt4 key购买 nike

我正在尝试让 onError 事件起作用,但到目前为止它只能在 Internet Explorer 9 中起作用。我已经尝试了几种代码,但基本上归结为:

<img class="a_toc_image" src="' + asap.imgurl + '" onError="this.src=\'images/no_image.png\';" />
  • Internet Explorer 9:
  • 成功:从我们的数据库中获取图像
  • 失败:显示 no_image.png

  • Chrome 20.0.11:

  • 成功:从我们的数据库中获取图像
  • 失败:只有空格

  • Firefox 14.0.1:

  • 成功:从我们的数据库中获取图像
  • 失败:损坏的图像图标

此代码的许多主要美学变体(例如省略或放入 "或 ')产生类似的结果。此特定变体在 Iexplorer 中产生堆栈溢出,但除此之外没有任何改变:

<img class="a_toc_image" src="' + asap.imgurl + '" onError=this.src="\images/no_image.png()" />

谁能告诉我这里出了什么问题以及为什么它只能在 Iexplorer 9 中工作?

谢谢!

-添加:

当在无法加载的图像上使用 Chrome 中的“检查元素”时,我看到了这个:

<img class="a_toc_image" src="images/no_image.png" onerror="this.src='images/no_image.png';">

所以它看起来生成了正确的输出,但由于某种原因不会显示图像,对吗?我刚才尝试放一个 .jpg 而不是 .png(也许 Chrome 不会显示 .png 图像),但这也没有解决任何问题。

-加法2,前面的代码

// General functions

var open_mask = function () {

//Get the screen height and width
var maskHeight = $(document).height();
var maskWidth = $(window).width();

//Set height and width to mask to fill up the whole screen
$('#mask').css({'width':maskWidth,'height':maskHeight});

//transition effect
$('#mask').fadeIn(1000);
$('#mask').fadeTo("fast",0.7);

};

var center_dialog = function (dialog) {

//Get the window height and width
var winH = $(window).height();
var winW = $(window).width();

var dialog_top = (winH/2-dialog.height()/2) + $(window).scrollTop();
var dialog_left = (winW/2-dialog.width()/2) + $(window).scrollLeft();

dialog_top = (dialog_top >= 0) ? dialog_top : 0;
dialog_left = (dialog_left >= 0) ? dialog_left : 0;

dialog.css('top', dialog_top);
dialog.css('left', dialog_left);
};


//function that creates posts

var updatepostHandler = function(postsJSON) {

$.each(postsJSON,function(i,asap) {

if(i === 0) {
first = asap.first;
last = asap.last;
} else {
if(asap.type === 'article') {
$('<div></div>') //create the HTML
.addClass('solid')
.html('<div class="titbox">' + asap.title + '</div> \
<div class="boxinsolid"> \
<div class="aubox">' + asap.authors + '</div> \
<div class="doibox"> DOI: ' + asap.doi + ' </div> \
<div class="joubox">' + asap.journal + '</div> \
</div> \
<div class="imgbox"> \
<img class="a_toc_image" src="' + asap.imgurl + '" onError="this.src=\'images/no_image.png\';" /> \
</div>')

.click(function(e) {
open_details(e, asap.id);
})
.prependTo($('#container'))
.slideDown('slow')
} else if(asap.type === 'ad') {
$('<div></div>') //create the HTML
.addClass('ad')
.html('<div class="titbox">' + asap.title + '</div> \
<div class="boxinsolid"> \
<div class="aubox">' + asap.authors + '</div> \
<div class="doibox">&nbsp;</div> \
<div class="joubox">' + asap.company + '</div> \
</div> \
<div class="imgbox"> \
<img class="a_toc_image" src="' + asap.image + '" onError="this.src=\'images/no_image.png\';" /> \
</div>')

.click(function(e) {
open_details(e, asap.ad_id);
})
.prependTo($('#container'))
.slideDown('slow')
}



};

});

};

最佳答案

我在 Chrome 和 FF 中尝试过,问题似乎出在单引号字符之前的(不必要的)反斜杠。请参阅此示例:http://jsfiddle.net/Yapad/

因此,您应该使用此代码,而不是您的代码:

<img class="a_toc_image" src="' + asap.imgurl + '" onerror="this.src='images/no_image.png';">

编辑:通过正确处理 asap.imgurl 来回避这个问题看起来像这样:

<img class="a_toc_image" src="' + (asap.imgurl != "" ? asap.imgurl:"/images/no_image.png") + '">

关于javascript - onError 在浏览器之间表现不同,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11794658/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com