JavaScript来源和加载图片:
<script>
function heat_map_load() {
var heat_map="http://example.com/login.png";
$(document).ready(function(){
var myImage = new Image();
$(myImage).load(function () {
$('#login img').css({ "width": "auto", "height": "auto" });
}).error(function () {
$('#login').hide();
}).attr('src', heat_map)
});
}
</script>
HTML:
<a class="profile" style="width: 100px;" id="web_login_p" href="#" data-chart="line" data-range="1m">heat map</a>
<div class="main" id="login" style="width:700px; height:300px;"></div>
JavaScript加载每次点击的图片:
$("#web_login_p").click(function() {
heat_map_load();
});
当我点击web_login_p时,我得到heat_map_load未定义的错误。我在这里缺少什么想法?
答案 0 :(得分:2)
heat_map_load
未定义,因为它仅在本地范围内可见,即document.ready
处理程序。
本杰明是对的,你应该在.ready
中移动点击处理程序。这是一个有效的例子:
$(document).ready(function(){
var heat_map = "http://www.google.com/images/srpr/logo11w.png";
function heat_map_load() {
var myImage = new Image();
$('#login').append($(myImage));
$(myImage).load(function () {
$('#login img').css({ "width": "auto", "height": "auto" });
}).error(function () {
$('#login').hide();
}).attr('src', heat_map);
}
$("#web_login_p").click(function() {
heat_map_load();
});
});