A. js如何判斷對象存不存在
直接用判斷 window.對象 是否是空的就行
比如判斷是否載入了jquery
if(window.jQuery){
//存在
}else{
//不存在
}
B. js判斷一個變數或對象是否存在
1、首先創建兩個文件,一個jstest.html,一個jstest.js文件。
C. 如何判斷javascript對象是否存在
直接判斷即可:
if(對象){
//對象存在
}else{
//對象不存在
}
D. js對象不存在的屬性為什麼叫undefined呢
undefined的英文意思就是【未定義】,不存在的變數也就是未定義的變數。
a.phone == undefined 這行代碼是否為 true 得看什麼情況。
如過 a 沒有聲明賦值(也就是未定義), 那麼這行代碼會直接報錯(Cannot read property 'phone' of undefined)。
如果 a 聲明賦值了,同時 a.phone 也聲明賦值了,那麼這行代碼為 false。
如果 a 聲明賦值了,但是 a.phone 沒有聲明賦值,那麼這行代碼為 true。
E. 如何判斷Javascript對象是否存在
<!--
判斷typeof obj運算的結果與"undefined"是否相等,就能判斷對象是否存在。
下面有例子。
-->
<html>
<body>
<script type="text/javascript">
var a=1;
if("undefined"==typeof a)
{
document.write("對象a不存在<br />");
}
else
{
document.write("對象a存在<br />");
}
if("undefined"!=typeof b)
{
document.write("對象b存在<br />");
}
else
{
document.write("對象b不存在<br />");
}
</script>
</body>
</html>
F. javascript 缺少對象
分開的時候要記得引用啊。。
<script language="javascript" src="你的路徑" type="text/javascrtip"> </script>
可能路徑不對,找不到函數.
G. 如何判斷Javascript對象是否存在
第一種寫法
var myObj;
if (!myObj){
var myObj = {};
}
第二種寫法
除了var命令,還可以有另一種改寫,也能得到正確的結果:
if (!window.myObj){
myObj = {};
}
window是javascript的頂層對象,所有的全局變數都是它的屬性。所以,判斷myobj是否為空,等同於判斷window對象是否有myobj屬性,這樣就可以避免因為myObj沒有定義而出現ReferenceError錯誤。不過,從代碼的規范性考慮,最好還是對第二行加上var:
if (!window.myObj){
var myObj = {};
}
或者寫成這樣:
if (!window.myObj){
window.myObj = {};
}
第三種寫法
上面這種寫法的缺點在於,在某些運行環境中(比如V8、Rhino),window未必是頂層對象。所以,考慮改寫成:
if (!this.myObj){
this.myObj = {};
}
在全局變數的層面中,this關鍵字總是指向頂層變數,所以就可以獨立於不同的運行環境。
第四種寫法
但是,上面這樣寫可讀性較差,而且this的指向是可變的,容易出錯,所以進一步改寫:
var global = this;
if (!global.myObj){
global.myObj = {};
}
用自定義變數global表示頂層對象,就清楚多了。
第五種寫法
還可以使用typeof運算符,判斷myObj是否有定義。
if (typeof myObj == "undefined"){
var myObj = {};
}
這是目前使用最廣泛的判斷javascript對象是否存在的方法。
第六種寫法
由於在已定義、但未賦值的情況下,myObj的值直接等於undefined,所以上面的寫法可以簡化:
if (myObj == undefined){
var myObj = {};
}
這里有兩個地方需要注意,首先第二行的var關鍵字不能少,否則會出現ReferenceError錯誤,其次undefined不能加單引號或雙引號,因為這里比較的是undefined這種數據類型,而不是"undefined"這個字元串。
第七種寫法
上面的寫法在"精確比較"(===)的情況下,依然成立:
if (myObj === undefined){
var myObj = {};
}
第八種寫法
根據javascript的語言設計,undefined == null,所以比較myObj是否等於null,也能得到正確結果:
if (myObj == null){
var myObj = {};
}
不過,雖然運行結果正確,但是從語義上看,這種判斷方法是錯的,應該避免。因為null指的是已經賦值為null的空對象,即這個對象實際上是有值的,而undefined指的是不存在或沒有賦值的對象。因此,這里只能使用"比較運算符"(==),如果這里使用"精確比較運算符"(===),就會出錯。
第九種寫法
還可以使用in運算符,判斷myObj是否為頂層對象的一個屬性:
if (!('myObj' in window)){
window.myObj = {};
}
第十種寫法
最後,使用hasOwnProperty方法,判斷myObj是否為頂層對象的一個屬性:
if (!this.hasOwnProperty('myObj')){
this.myObj = {};
}
總結
1. 如果只判斷對象是否存在,推薦使用第五種寫法。
2. 如果除了對象是否存在,還要判斷對象是否有null值,推薦使用第一種寫法。
3. 除非特殊情況,所有變數都應該使用var命令聲明。
4. 為了跨平台,建議避免使用window表示頂層對象。
5.
在Javascript語言中,null和undefined容易產生混淆。在可能同時涉及兩者的情況下,建議使用"精確比較"運算符(===)。
H. 如何判斷Javascript對象是否存在
1、直接判斷對象不為null
if (!myObj) {
var myObj = { };
}
Javascript語言是"先解析,後運行",解析時就已經完成了變數聲明
2、使用window對象判斷某對象是否存在
if (!window.myObj) {
var myObj = { };
}
3、使用this對象判斷某對象是否存在
if (!this.myObj) {
this.myObj = { };
}
在某些運行環境中(比如V8、Rhino),window未必是頂層對象。所以,考慮改成this進行判斷,在全局變數的層面中,this關鍵字總是指向頂層變數,所以就可以獨立於不同的運行環境。
4、方法三這樣寫可讀性較差,而且this的指向是可變的,容易出錯,所以進一步改寫:
var global = this;
if (!global.myObj) {
global.myObj = { };
}
5、可以使用typeof運算符,判斷myObj是否有定義。
if (typeof myObj == "undefined") {
var myObj = { };
}
這是目前使用最廣泛的判斷javascript對象是否存在的方法。
6、由於在已定義、但未賦值的情況下,myObj的值直接等於undefined,所以上面的寫法可以簡化:
if (myObj == undefined) {
var myObj = { };
}
有兩個地方需要注意,首先第二行的var關鍵字不能少,否則會出現ReferenceError錯誤,其次undefined不能加單引號或雙引號,因為比較的是undefined這種數據類型,而不是"undefined"這個字元串。
7、用精確比較===判斷對象是否存在
if (myObj === undefined) {
var myObj = { };
}
8、根據javascript的語言設計,undefined == null,所以比較myObj是否等於null,也能得到正確結果
if (myObj == null) {
var myObj = { };
}
不過,雖然運行結果正確,但是從語義上看,這種判斷方法是錯的,應該避免。
因為null指的是已經賦值為null的空對象,即這個對象實際上是有值的,而undefined指的是不存在或沒有賦值的對象。
因此,這里只能使用"比較運算符"(==),如果這里使用"精確比較運算符"(===),就會出錯
9、還可以使用in運算符,判斷myObj是否為頂層對象的一個屬性
if (!('myObj' in window)) {
window.myObj = { };
}
10、使用hasOwnProperty方法,判斷myObj是否為頂層對象的一個屬性
if (!this.hasOwnProperty('myObj')) {
this.myObj = { };
}
總結:
1、如果只判斷對象是否存在,推薦使用第五種寫法。
2、如果除了對象是否存在,還要判斷對象是否有null值,推薦使用第一種寫法。
3、除非特殊情況,所有變數都應該使用var命令聲明。
4、為了跨平台,建議避免使用window表示頂層對象。
5、在Javascript語言中,null和undefined容易產生混淆。在可能同時涉及兩者的情況下,建議使用"精確比較"運算符(===)。
I. 如何判斷Javascript對象是否存在
1. 如果只判斷對象是否存在,推薦使用第五種寫法。
2. 如果除了對象是否存在,還要判斷對象是否有null值,推薦使用第一種寫法。
3. 除非特殊情況,所有變數都應該使用var命令聲明。
4. 為了跨平台,建議避免使用window表示頂層對象。
5. 在Javascript語言中,null和undefined容易產生混淆。在可能同時涉及兩者的情況下,建議使用"精確比較"運算符(===)。
(完)
J. 如何判斷Javascript對象是否存在
<!--
如果typeof objectname返回字元串undefined,說明對象不存在;否則對象存在。
下面有例子。
-->
<html>
<body>
<script type="text/javascript">
var n=1,str="hi",d=new Date();
if("undefined"!=typeof n)
{
document.write("對象n存在<br />");
}
else
{
document.write("對象n不存在<br />");
}
if("undefined"!=typeof me)
{
document.write("對象me存在<br />");
}
else
{
document.write("對象me不存在<br />");
}
if("undefined"!=typeof str)
{
document.write("對象str存在<br />");
}
else
{
document.write("對象str不存在<br />");
}
if("undefined"!=typeof d)
{
document.write("對象d存在<br />");
}
else
{
document.write("對象d不存在<br />");
}
</script>
</body>
</html>