❶ javascript 函數里如何修改全局變數
函數是不會自己執行的,也就是說,你在定義了imgWidth這個函數之後,並不會馬止執行,而是在你調用它之後才會執行,那麼在你的代碼中,alert(hy1[0][1]);這一句執行的時候imgWidth並沒有執行,那麼hy1[0][1]的值還沒有被改變,也就是undefined<br>你應該是使用過imgWidth函數之後再用alert(hy1[0][1])來看變數的值
❷ 當javascript中函數嵌套函數,那麼在函數體里的子函數能使用到函數體外(所用函數之外)的全局變數嗎
可以的。
所有函數在執行的時候,都會生成一個變數對象:
變數對象相當於一個棧,棧的第一個元素是函數當前的作用域的變數,下一個元素就是包含該函數的作用域(如果存在)。最後,到全局環境的時候,會在棧的結尾加上幾個全局對象:window、Math、 Date 等 javascript原生對象。
當在函數調用變數時,將會在變數對象中循環搜索是否存在該變數,逐次搜索直到最後的全局對象。當搜索的層次越深,訪問變數的效率越低。
❸ javascript 函數的參數 是局部變數嗎
首先,應當知道什麼是局部變數,局部變數(Local variables)指在程序中只在特定過程或函數中可以訪問的變數。
javascript函數參數的作用域於參數類型無關,也就是說不管參數是函數還是其他類型,這個參數的作用域只在接收這個參數的函數內有效,所以說他是個局部變數,只可以在這個方法內部使用
例:
functionadd(x){
alent("add方法內的x="+x)
}
alent("add方法外的x="+x)
上面只會在方法內部彈出x的值,而在add方法的外部是不會彈出x的值,所以javascript的方法參數是一個只在方法內部有作用的局部變數。
❹ 在JS中怎麼獲取另外函數裡面的變數
根據函數作用域鏈,變數是一層一層向作用域鏈外部逐層尋找距離最近的定義。所以,在函數內部,是可以訪問到外部的,也就是上級的變數。但是,在函數外部,是無法訪問到函數內部的變數的。如果你想訪問,可以通過,閉包,定義全局變數等方法來獲取。
❺ javascript為什麼這樣寫訪問不到函數裡面的變數
你傳的aaa的函數,是aaa的返回值,如果aaa沒有返回值的話,會報錯的,,
還有就是你說的讀不了a的值,是因為在js中如果你在函數內部定義的變數,那麼是屬於局部變數的。如果你要訪問a的值,你應該在函數外部定義a的值
❻ 怎麼調用function函數中的變數
// 1, 方法調用模式
// 當一個函數被保存為對象的一個屬性時,我們稱之它為該對象的一個方法,那麼this被綁定到該對象上
var myObject={
name : "myObject" ,
value : 0 ,
increment : function(num){
this.value += typeof(num) === 'number' ? num : 0;
return this;
} ,
toString : function(){
return '[Object:' + this.name + ' {value:' + this.value + '}]';
}
}
alert(myObject.increment(10).increment(20).toString()); // [Object:myObject {value:30}]
// 2, 函數調用模式
// 當一個函數並非一個對象的函數時,那麼它被當作一個函數來調用,this被綁定到全局對象上。這是語言設計的一個錯誤。倘若語言設計正確,當內部函數調用時,this應該仍然綁定到外部函數的this變數上
var myObject={
name : "myObject" ,
value : 0 ,
increment : function(num){
this.value += typeof(num) === 'number' ? num : 0;
return this;
} ,
toString : function(){
return '[Object:' + this.name + ' {value:' + this.value + '}]';
},
getInfo: function(){
var self=this;
return (function(){
//return this.toString(); // 內部匿名函數中this指向了全局對象window, 輸出 [object Window]
return self.toString(); // 定義一個變數selft並給它賦值為this,那麼內部函數通過該變數訪問到指向該對象的this
})();
}
}
alert(myObject.increment(10).increment(20).toString()); // [Object:myObject {value:30}]
// 3, 構造器調用模式
// JavaScript是一門基於原型繼承的語言, 這意味著對象可以直接從其他對象繼承屬性, 該語言是無類別的。
// 如果一個函數前面帶上new來調用,那麼將創建一個隱藏連接到該函數的prototype成員的新對象,同時this將會被綁定到構造函數的實例上。
function MyObject(name){
this.name = name || 'MyObject';
this.value=0;
this.increment = function(num){
this.value += typeof(num) === 'number' ? num : 0;
};
this.toString = function(){
return '[Object:' + this.name + ' {value:' + this.value + '}]';
}
this.target = this;
}
❼ 關於JS 函數里 修改 全局變數 的問題
因為你想通過change()函數來改變全局變數hello的值,可是你在alert操作前並沒有調用change()函數。應該在alert操作前先調用下change change();alert(hello);
❽ JS函數如何調用別的函數變數。
函數內部變數(局部變數)一般是不可以給函數外部其它的函數使用的。但是,可以通過返回一個閉包,這樣外部的函數就可以使用了。(使用時必須小心內部函數中的this指針)
如:
functiona(){
varx=123;
functionb(){
alert(x);
}
return{x:x,func:b};
}
vartest=a();//a執行後返回一個對象,這個對象包含a內部的變數和函數
alert(test.x);//彈出a內部的x;
test.func();//執行b函數
❾ JS中一個函數里的變數值,怎麼可以直接在另外一個函數里用引用
定義到公共函數的任意位置都可以