- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试让 onError 事件起作用,但到目前为止它只能在 Internet Explorer 9 中起作用。我已经尝试了几种代码,但基本上归结为:
<img class="a_toc_image" src="' + asap.imgurl + '" onError="this.src=\'images/no_image.png\';" />
失败:显示 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"> </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/
在Elm中,我有一个简单的图像,我希望将其替换为一些“缺少”的onerror图像。因此,我添加了一个“onerror”属性: img [ src "broken-link.png" ,
我正在编写一个程序来使用 os.walk 遍历文件系统。 我的 for 循环使用 os.walk,onerror 函数如下: def walk_error(os_error): return(
这可能是一个非常明显的问题,但请解释一下 xhr 和 xhr.upload 之间的区别是什么? 我的用例是我正在将文件上传到服务器,但假设服务器出现故障。在这种情况下,我应该处理 xhr.onerro
我是 Flutter 的新手,我想了解我的错误处理程序有什么问题: import 'package:http/http.dart' as http; try { var response = aw
我的 VBA 中有以下示例代码。每当我遇到与系统相关的错误时,我想显示我自己的错误消息。但是下面的代码不起作用。 VBA 告诉 Type Mismatch 我想 Hello your date is
我的代码是这样的: function func1() { document.getElementById("img").src="pic.jpg"; ---stament2---
好吧,每当加载广告网络提供的图像时出现问题时,我都会尝试运行一些 JavaScript。 广告显示得很好,但我的脚本无论如何都会被调用。我是否以错误的方式处理这个问题? 代码: functi
我正在尝试控制背景是否可用。我看到到处都在使用 onerror,但不适合我。我有 bg 文件夹和 background1.jpg 到 background4.jpg 背景图片。对于前 4 个没有问题。
我在 Android 应用程序的 MainActivity 中编写了以下代码。当我运行以下代码时,它不会抛出任何异常并且 onError() 也不会被调用。但是我看到 onSuccess: testi
我有一张图片正在通过使用 javascript 更改图片的 src 进行更新。我添加了一个 error 事件监听器来测试图像是否损坏,如果是则重新加载图像。但如果它没有损坏,我想删除 error 事件
我需要在我的 TestCafe 测试中抑制错误(错误来自模拟页面)。示例代码: function stoperror() { try { thi
我有以下外部脚本标签(但 self 控制的 javascript 文件): 脚本并不重要,存在一个很好的后备方案。我想触发我的回退: 如果 test.js 不可用(这有效) 手动在 test.js
我有一个非常奇怪的情况,无法设法解决。 const handleImageError = e => { e.target.onerror = null; e.target.src =
我正在尝试让 onError 事件起作用,但到目前为止它只能在 Internet Explorer 9 中起作用。我已经尝试了几种代码,但基本上归结为: Internet Explorer 9: 成
当 src 中指定的其他图像不存在时,我试图显示默认图像,所以我这样做了: '; 问题是我仍然得到损坏的缩略图。奇怪的是:如果我切换 src,那么我将 assets/img/default-avata
鉴于以下情况: 为什么从未调用 Subscribe 中的 OnError 处理程序? var observable = Observable.Create( async (o, c) =>
ASP.NET (4.0) 中的 UserControls 继承自 System.Web.UI.UserControl。 VisualStudio 智能感知建议 OnError 作为 Template
在我的图像上,我设置了 onerror属性,以便在图像由于某种原因不可用的情况下使用占位符: 现在,它看起来像 onerror has been deprecated ,但我找不到任何关于处理错误的
我正在测试这段代码。 service.getProducts() .subscribeOn(Schedulers.io()) .observeOn(An
我正在考虑在我支持的应用程序中重新工作并简化我们的错误处理。我们目前的所有页面都继承自我们创建的基类,而该基类显然又继承自 System.Web.UI.Page。在这个基类中,OnError 方法当前
我是一名优秀的程序员,十分优秀!