国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

js中控制臺報錯:Uncaught TypeError: Cannot read properties of undefined (reading ‘a(chǎn)ppendChild‘)

這篇具有很好參考價值的文章主要介紹了js中控制臺報錯:Uncaught TypeError: Cannot read properties of undefined (reading ‘a(chǎn)ppendChild‘)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

控制臺錯誤提示為:

js中控制臺報錯:Uncaught TypeError: Cannot read properties of undefined (reading ‘a(chǎn)ppendChild‘),報錯合集,javascript,開發(fā)語言,vscode,前端,html

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

也就是說,你在使用appendChild時的父元素上沒有這個屬性,所以沒法使用。

此時,需要檢查你獲取元素是否有誤,或者是邏輯問題。

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

	// 頁面初始化
	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");

				// 給當前這個li賦值內(nèi)容
				li.innerHTML = `<p>
									<i class="iconfont icon-bofang"></i>
									<span>${cur.name}</span>
								</p>
								<p>
									<span>${cur.time}開播</span>
									<span class="start">播放視頻</span>
								</p>`;

				// 添加到ul中 
				ul.appendChild(li);
			});


			// 將ul添加到div中
			div.appendChild(ul);

			// 將div添加到kecheng中
			kecheng.appendChild(div);

		});

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

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

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

js中控制臺報錯:Uncaught TypeError: Cannot read properties of undefined (reading ‘a(chǎn)ppendChild‘),報錯合集,javascript,開發(fā)語言,vscode,前端,html

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

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

(編程小白一位,如有錯誤,還請指正,謝謝~)文章來源地址http://www.zghlxwxcb.cn/news/detail-552639.html

到了這里,關(guān)于js中控制臺報錯:Uncaught TypeError: Cannot read properties of undefined (reading ‘a(chǎn)ppendChild‘)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔相關(guān)法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包