js控制臺報錯UncaughtTypeError:Cannotreadpropertiesofundefined(reading‘appendChild‘)的解決

    控制臺錯誤提示為: 意思是:未捕獲的類型錯誤: 無法讀取未定義的屬性(讀取 appendchild) 也就是說,你在使用appendChild時的父元素上沒有這個屬性,所以沒法使用。 此時,需要檢查你獲

    控制臺錯誤提示為:

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

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

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

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

    // 頁面初始化
    	bindData(classList);
    	// 獲取元素
    	var kecheng = document.querySelector(".classlist .kecheng");
        // 數據綁定
    	// data:數據(數組)
    	function bindData(data) {
    		// 循環遍歷數組
    		data.forEach(function(val, index) {
    			// console.log(val,index);
    			// 創建章
    			var div = document.createElement("div");
    			// 設置類名
    			div.className = "detail";
    			// 賦值內容
    			div.innerHTML =
    				`<p class="title">${val.title}(含${val.num}期)<i class="iconfont iconupanddown ${index < 3 ?'icon-top1':'icon-down'}"></i></p>`;
    			// 創建ul
    			var ul = document.createElement("ul");
    			// 設置類名
    			ul.className = index < 3 ? "active" : "";
    			// 創建節
    			// console.log(val.list);
    			val.list.forEach(function(cur) {
    				// 創建li
    				var li = document.createElement("li");
    				// 給當前這個li賦值內容
    				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);
    		});

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

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

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

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

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

    到此這篇關于js控制臺報錯Uncaught TypeError: Cannot read properties of undefined (reading ‘appendChild‘)的解決的文章就介紹到這了,更多相關js控制臺報錯Uncaught TypeError內容請搜索技圈網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持技圈網!

    【文章原創作者:濱海網站設計 http://www.1234xp.com/binhai.html 網絡轉載請說明出處】
    聲明:所有內容來自互聯網搜索結果,不保證100%準確性,僅供參考。如若本站內容侵犯了原著者的合法權益,可聯系我們進行處理。
    發表評論
    更多 網友評論0 條評論)
    暫無評論

    返回頂部

    主站蜘蛛池模板: 色妞色视频一区二区三区四区| 久久久国产精品无码一区二区三区 | 亚洲视频一区二区在线观看| 无码av免费一区二区三区试看| 国产成人一区二区三中文| 国产日韩高清一区二区三区| 久久青青草原一区二区| 97精品国产一区二区三区| 99久久国产精品免费一区二区| 日本免费电影一区| 亚洲国产成人久久一区二区三区 | 久久se精品一区二区影院| 国产美女av在线一区| 福利一区二区视频| 亚洲第一区二区快射影院| 伊人激情AV一区二区三区| 日本一区二区三区在线视频观看免费 | 国产色综合一区二区三区| 国产精品一区二区av不卡| 亚洲日本中文字幕一区二区三区| 无码少妇精品一区二区免费动态| 熟妇人妻一区二区三区四区| 福利一区二区三区视频午夜观看| 国产一区二区三区亚洲综合| 亚洲高清一区二区三区| 一区二区三区伦理高清| 人妻激情偷乱视频一区二区三区| 精品在线一区二区| 精品乱码一区二区三区在线| 亚洲一区二区三区国产精华液| 免费无码一区二区三区蜜桃大| 相泽南亚洲一区二区在线播放| 国产精品自拍一区| 伊人久久一区二区三区无码| 无码人妻一区二区三区兔费| 国产精品无码一区二区三区在 | 无码精品人妻一区二区三区漫画 | 国产伦理一区二区三区| 国产精品一区二区综合| 国产亚洲福利一区二区免费看 | 国产精品一区二区在线观看|