扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
html注册事件向引用方法中的传参问题,两个方式:
创新互联是一家专注于成都做网站、网站设计与策划设计,珠山网站建设哪家好?创新互联做网站,专注于网站建设10余年,网设计领域的专业建站公司;建站业务涵盖:珠山等地区。珠山做网站价格咨询:028-86922220
html
head
script
function bbb(event){
event = window.event || event;
var srcEle = event.target || event.srcElement;
alert(srcEle.value);
}
function ccc(cc){
alert(cc.value);
}
/script
/head
body
input type="text" value="用event方式" onblur="bbb()"/
input type="text" value="对象传递" onblur="ccc(this)"/
/body
/html
你说js函数的传参是按值传递,应该是看到《js高级》里面作者这么说的吧,其实有不少人对作者的观点提出了质疑,有的人觉得如果参数是引用类型,那么就是按引用传递的,还有一种说法叫“按共享传递”。
我个人偏向于的观点是:如果参数是js基本数据类型,那么就是按值传递;如果是引用类型如对象、数组、函数,那么就是按引用传递。用这个观点去解释你的例子,应该是没有矛盾的地方的。①处按照js对象的比较运算规则,只有全等号(据说比较对象时,“===”和“==”是没有区别的)两侧的变量指向的是同一个对象的引用,才返回true,即按引用传递。在“peo = {...}”这一行,实际上是创建了一个函数内的局部对象,开辟了新的内存地址,并将peo变量指向该处,而之前的person变量指向的对象不变,故而②比较的是两个指向不同对象的变量,返回false。
你可以这么去理解js函数传参的过程:js解析器在分析js的函数声明代码时,如果函数有带参数,实际上是在开始时加了一行代码:var 参数1,参数2...;即将参数隐性的声明为函数的局部变量,没有赋值(下面的函数例子可以说明这点,第一个函数虽然声明是有形参,但是调用执行时没有传参,即a只声明未赋值,所以是undefined;第二个函数的a不存在,所以报错)。等到函数真正被调用,传进来实参的时候,只是将实参变量赋给了形参变量,比如你的例子中,函数调用执行时会自动加一句:peo = person;即两个不同的变量指向了同一个对象,这自然就是按引用传递。
function aa(a) {
console.log(a)
}
aa() //输出undefined
function ab() {
console.log(a)
}
ab() //报错,Uncaught ReferenceError: a is not defined
方法一:通过事件在html中的内联方式来传递参数(假定变量x是参数,下同):
input type="button" value="点我" onclick="var x=123;test(x);"/
script
function test(x){
alert(x);
}
/script
方法二:通过全局变量来传递参数:
input id="abc" type="button" value="点我"/
script
var x=123;
window.onload=function(){
document.getElementById("abc").onclick=function(){
alert(x);
}
}
/script
方法三:通过对象的自定义属性来传递参数:
input id="abc" type="button" value="点我"/
script
window.onload=function(){
var abc=document.getElementById("abc");
abc.x=123;
abc.onclick=function(){
alert(this.x);
}
}
/script
方法四:利用闭包:
input id="abc" type="button" value="点我"/
script
window.onload=function(){
(function(x){
document.getElementById("abc").onclick=function(){
alert(x);
}
})(123);
}
/script
暂时就想到这么多了,肯定还有其他方法的。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流