js控制臺(tái)報(bào)錯(cuò)UncaughtTypeError:Cannotreadpropertiesofundefined(reading‘a(chǎn)ppendChild‘)的解決

    控制臺(tái)錯(cuò)誤提示為: 意思是:未捕獲的類型錯(cuò)誤: 無(wú)法讀取未定義的屬性(讀取 appendchild) 也就是說(shuō),你在使用appendChild時(shí)的父元素上沒(méi)有這個(gè)屬性,所以沒(méi)法使用。 此時(shí),需要檢查你獲

    控制臺(tái)錯(cuò)誤提示為:

    意思是:未捕獲的類型錯(cuò)誤: 無(wú)法讀取未定義的屬性(讀取‘ appendchild’)

    也就是說(shuō),你在使用appendChild時(shí)的父元素上沒(méi)有這個(gè)屬性,所以沒(méi)法使用。

    此時(shí),需要檢查你獲取元素是否有誤,或者是邏輯問(wèn)題。

    此時(shí)我的js代碼為:(只展示引起錯(cuò)誤的部分)

    // 頁(yè)面初始化
    	bindData(classList);
    	// 獲取元素
    	var kecheng = document.querySelector(".classlist .kecheng");
        // 數(shù)據(jù)綁定
    	// data:數(shù)據(jù)(數(shù)組)
    	function bindData(data) {
    		// 循環(huán)遍歷數(shù)組
    		data.forEach(function(val, index) {
    			// console.log(val,index);
    			// 創(chuàng)建章
    			var div = document.createElement("div");
    			// 設(shè)置類名
    			div.className = "detail";
    			// 賦值內(nèi)容
    			div.innerHTML =
    				`<p class="title">${val.title}(含${val.num}期)<i class="iconfont iconupanddown ${index < 3 ?'icon-top1':'icon-down'}"></i></p>`;
    			// 創(chuàng)建ul
    			var ul = document.createElement("ul");
    			// 設(shè)置類名
    			ul.className = index < 3 ? "active" : "";
    			// 創(chuàng)建節(jié)
    			// console.log(val.list);
    			val.list.forEach(function(cur) {
    				// 創(chuàng)建li
    				var li = document.createElement("li");
    				// 給當(dāng)前這個(gè)li賦值內(nèi)容
    				li.innerHTML = `<p>
    									<i class="iconfont icon-bofang"></i>
    									<span>${cur.name}</span>
    								</p>
    								<p>
    									<span>${cur.time}開(kāi)播</span>
    									<span class="start">播放視頻</span>
    								</p>`;
    				// 添加到ul中 
    				ul.appendChild(li);
    			});
    			// 將ul添加到div中
    			div.appendChild(ul);
    			// 將div添加到kecheng中
    			kecheng.appendChild(div);
    		});

    ?從上圖可以看出,我把獲取元素寫(xiě)到了調(diào)用方法的后面,且報(bào)錯(cuò)時(shí)提示的行數(shù)對(duì)應(yīng)的內(nèi)容是:kecheng.appendChild(div);也就是說(shuō)是kecheng在獲取或者別的方面出了錯(cuò)。

    根據(jù)預(yù)解析的概念:就是代碼在真正執(zhí)行之前將var和funtion進(jìn)行提前的加載。(var只聲明不定義,function聲明+定義 )

    得知:在代碼執(zhí)行前的預(yù)加載中是先把函數(shù)bindData(classList)調(diào)用,之后才定義了課程,所以在函數(shù)bindData中最后一行的kecheng還未定義。(預(yù)加載思路圖大致如下)

    ?所以,只要把函數(shù)調(diào)用放在獲取元素之后就可以避免這類型錯(cuò)誤。如下:

        // 獲取元素
    	var kecheng = document.querySelector(".classlist .kecheng");
    	// 頁(yè)面初始化
    	bindData(classList);

    到此這篇關(guān)于js控制臺(tái)報(bào)錯(cuò)Uncaught TypeError: Cannot read properties of undefined (reading ‘a(chǎn)ppendChild‘)的解決的文章就介紹到這了,更多相關(guān)js控制臺(tái)報(bào)錯(cuò)Uncaught TypeError內(nèi)容請(qǐng)搜索技圈網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持技圈網(wǎng)!

    【文章原創(chuàng)作者:濱海網(wǎng)站設(shè)計(jì) http://www.1234xp.com/binhai.html 網(wǎng)絡(luò)轉(zhuǎn)載請(qǐng)說(shuō)明出處】
    聲明:所有內(nèi)容來(lái)自互聯(lián)網(wǎng)搜索結(jié)果,不保證100%準(zhǔn)確性,僅供參考。如若本站內(nèi)容侵犯了原著者的合法權(quán)益,可聯(lián)系我們進(jìn)行處理。
    發(fā)表評(píng)論
    更多 網(wǎng)友評(píng)論0 條評(píng)論)
    暫無(wú)評(píng)論

    返回頂部

    主站蜘蛛池模板: 看电影来5566一区.二区| 视频精品一区二区三区| 亚洲AV无码一区二区三区电影| 亚洲国产成人一区二区精品区| 伦理一区二区三区| 亚洲熟妇av一区二区三区漫画| 久久一本一区二区三区| 精品福利一区二区三区免费视频| 亚洲国产系列一区二区三区| 精品国产日韩亚洲一区91| 精品乱子伦一区二区三区高清免费播放| 国产成人精品无人区一区| 亚洲国产精品一区二区久久hs| 中文字幕一区在线观看视频 | 久久精品国产一区二区电影| 亚洲线精品一区二区三区 | 亚洲av日韩综合一区二区三区| 成人无码精品一区二区三区| 国产无码一区二区在线| 国产精品无码AV一区二区三区 | 国产高清一区二区三区| 精品国产AV无码一区二区三区 | 国产美女口爆吞精一区二区| 中文字幕一区二区三区在线不卡| 人妻无码一区二区不卡无码av| 无码人妻一区二区三区免费| 中文字幕一区二区三区永久| 蜜芽亚洲av无码一区二区三区| 在线视频一区二区三区三区不卡 | 国产精品主播一区二区| 亚洲性色精品一区二区在线| 久久精品一区二区三区中文字幕 | 午夜福利一区二区三区高清视频 | 成人无码一区二区三区| 少妇特黄A一区二区三区| 国产在线观看一区二区三区| 久久国产精品视频一区| 国产精品电影一区二区三区| 制服丝袜一区在线| 中文字幕人妻丝袜乱一区三区 | 亚洲AV无码一区二区一二区|