[英]Calling javascript function inside HTML tag
我有以下内容。
<a href="#" onclick="hello()">click me</a>
我有一个Javascript文件
$(document).ready(function() {
function hello() {
alert('hi');
}
});
但是当我点击“点击我”时,警报没有被触发。 它说“你好”没有定义。 我删除document.ready,它的工作原理。
这是因为在整个文档准备好之前没有定义“hello”,但是当渲染上面的“anchor”标记时,它找不到该函数?
有什么方法可以让这个工作吗?
您还可以在Anchor Tag中使用HREF属性和javascript: keyword来调用JavaScript函数:
<a href="javascript:hello()">click me</a>
您的hello()
函数声明不在全局范围内,因此来自尝试在全局范围内调用它的HTML的调用无法找到它。 您可以通过将hello()
函数移动到全局范围来修复它:
function hello() {
alert('hi');
}
$(document).ready(function() {
});
或者在全球范围内宣布:
$(document).ready(function() {
window.hello = function() {
alert('hi');
}
});
<a href="#" id="say_hello">click me</a>
<script type="text/javascript">
$(document).ready(function() {
$('#say_hello').click(function() {
hello();
});
});
function hello() {
alert('hi');
}
</script>
hello未定义的原因是因为Hello()仅存在于DomReady回调的上下文中。 您需要在全局上下文中定义Hello()。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.