91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript錯誤的經典問題有哪些

發布時間:2022-02-21 16:53:04 來源:億速云 閱讀:140 作者:iii 欄目:開發技術

這篇文章主要介紹“JavaScript錯誤的經典問題有哪些”,在日常操作中,相信很多人在JavaScript錯誤的經典問題有哪些問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”JavaScript錯誤的經典問題有哪些”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

1. Uncaught TypeError: Cannot read property

如果你是一個 JavaScript 開發人員,你可能已經看到過這個錯誤。當你讀取屬性或在未定義對象上調用方法時,Chrome 中就會發生這種情況。你可以在 Chrome 開發者控制臺中輕松進行測試。

發生這種情況的原因有很多,但常見的原因是渲染 UI 組件時狀態初始化不當。讓我們來看一個在現實應用中如何發生這種情況的示例。我們將選擇React,但是不正確初始化的相同原理也適用于AngularVue或任何其他框架。

class Quiz extends Component {
  componentWillMount() {
    axios.get('/thedata').then(res => {
      this.setState({items: res.data});
    });
  }
  render() {
    return (
      <ul>
        {this.state.items.map(item =>
          <li key={item.id}>{item.name}</li>
        )}
      </ul>
    );
  }
}

這里有兩件重要的事情要意識到:

  • 組件的狀態(例如 this.state)以 undefined 狀態開始使用。

  • 當你異步獲取數據時,無論數據是在構造函數 componentWillMount 還是 componentDidMount 中獲取,組件都將在數據加載之前至少渲染一次。當Quiz第一次渲染時,this.state.itemsundefined。這反過來又意味著ItemList會得到未定義的items,你會在控制臺中得到一個錯誤——"UncaughtTypeError: Cannot read property 'map' of undefined "的錯誤。

這很容易解決,最簡單的方法:在構造函數中使用合理的默認值初始化狀態。

class Quiz extends Component {
  // 添加了這個:
  constructor(props) {
    super(props);
    this.state = {
      items: [] // 默認值
    };
  }
  componentWillMount() {
    axios.get('/thedata').then(res => {
      this.setState({items: res.data});
    });
  }
  render() {
    return (
      <ul>
        {this.state.items.map(item =>
          <li key={item.id}>{item.name}</li>
        )}
      </ul>
    );
  }
}

你的應用程序中的實際代碼可能會有不同,但我希望已經給了你足夠的線索,讓你在你的應用程序中修復或避免這個問題。如果沒有,請繼續閱讀,因為我將在下面介紹有關相關錯誤的更多示例。

2. TypeError: ‘undefined’ is not an object (evaluating

這是在 Safari 中讀取屬性或調用undefined對象上的方法時發生的錯誤,你可以在Safari開發者控制臺中非常輕松地進行測試。這基本上與上述針對 Chrome 的錯誤相同,但 Safari 使用了不同的錯誤消息。

3. TypeError: null is not an object (evaluating

這是在 Safari 中讀取屬性或調用null對象上的方法時發生的錯誤,你可以在 Safari 開發者控制臺中非常輕松地進行測試。

有趣的是,在JavaScript中,nullundefined不相同,這就是為什么我們看到兩個不同的錯誤消息的原因。undefined通常是尚未分配的變量,而null表示該值為空白。 要驗證它們是否相等,請嘗試使用嚴格相等運算符。

在實際示例中可能發生這種錯誤的一種方式是,在加載元素之前嘗試在JavaScript中使用DOM元素,這是因為DOM API對于空白的對象引用返回null

任何執行和處理DOM元素的JS代碼都應在創建DOM元素后執行。JS代碼按照HTML格式從上到下進行解釋,所以,如果在DOM元素之前有一個標簽,那么在瀏覽器解析HTML頁面的時候,腳本標簽內的JS代碼就會被執行。如果在加載腳本之前尚未創建DOM元素,則會出現此錯誤。

在此示例中,我們可以通過添加事件偵聽器來解決該問題,該事件偵聽器將在頁面準備就緒時通知我們。一旦觸發了 addEventListenerinit() 方法就可以使用DOM元素。

<script>
  function init() {
    var myButton = document.getElementById("myButton");
    var myTextfield = document.getElementById("myTextfield");
    myButton.onclick = function() {
      var userName = myTextfield.value;
    }
  }
  document.addEventListener('readystatechange', function() {
    if (document.readyState === "complete") {
      init();
    }
  });
</script>
<form>
  <input type="text" id="myTextfield" placeholder="Type your name" />
  <input type="button" id="myButton" value="Go" />
</form>

4. (unknown): Script error

當未捕獲的JavaScript錯誤違反跨源策略跨越域邊界時,將發生腳本錯誤。例如,如果你將你的JavaScript代碼托管在CDN上,任何未被捕獲的錯誤(冒泡到window.onerror處理程序中的錯誤,而不是在try-catch中被捕獲的錯誤)都會被報告為 "Script error",而不是包含有用的信息。這是一種瀏覽器安全措施,旨在防止跨域傳遞數據,否則該域將無法通信。

要獲取真實的錯誤消息,請執行以下操作。

發送Access-Control-Allow-Origin標頭

Access-Control-Allow-Origin 標頭設置為 * 表示可以從任何域正確訪問資源。你可以根據需要將 * 替換為您的域:例如,Access-Control-Allow-Origin:www.example.com。但是,處理多個域比較復雜,如果使用 CDN 可能會出現緩存問題,那么可能不值得花費精力。

以下是一些有關如何在各種環境中設置此標頭的示例:

Apache

在將提供JavaScript文件的文件夾中,創建一個具有以下內容的 .htaccess 文件:

Header add Access-Control-Allow-Origin "*"

Nginx

add_header指令添加到提供JavaScript文件的location塊中:

location ~ ^/assets/ {
    add_header Access-Control-Allow-Origin *;
}

HAProxy

將以下內容添加到提供JavaScript文件的asset后端:

rspadd Access-Control-Allow-Origin:\ *

在腳本標簽上設置crossorigin =“ anonymous”

在你的HTML源代碼中,對于您設置了 Access-Control-Allow-Origin 標頭的每個腳本,在script標記上設置crossorigin="anonymous"。在script標記上添加 crossorigin 屬性之前,請確保已驗證是否已為腳本文件發送了標頭。在Firefox中,如果存在 crossorigin 屬性,但沒有 Access-Control-Allow-Origin 標頭,則不會執行腳本。

5. TypeError: Object doesn’t support property

這是在 IE 中發生的錯誤,當您調用undefined的方法時,你可以在 IE 開發人員控制臺中對此進行測試。

這等效于 Chrome 中的錯誤“ TypeError:‘undefined’ is not a function”。是的,對于相同的邏輯錯誤,不同的瀏覽器可能具有不同的錯誤消息。

這是 IE 在采用JavaScript命名空間的 Web 應用程序中常見的問題,在這種情況下,99.9%的問題是 IE 無法將當前名稱空間中的方法綁定到 this 關鍵字。

例如,如果你的JS命名空間 Rollbar 使用 isAwesome 方法。通常,如果你在 Rollbar 名稱空間中,則可以使用以下語法調用 isAwesome 方法:

this.isAwesome();

Chrome,Firefox 和 Opera 將很樂意接受此語法。另一方面,IE 則不會。因此,在使用 JS命名空間時,最安全的方法是用實際的命名空間作為前綴。

Rollbar.isAwesome();

6. TypeError: ‘undefined’ is not a function

這是在 Chrome 中發生的錯誤,當你調用undefined的函數時。你可以在 Chrome 開發者控制臺和Mozilla Firefox開發者控制臺中對此進行測試。

隨著這些年來JavaScript的編碼技術和設計模式越來越復雜,在回調和閉包中的自引用作用域也相應地增多,這也是相當常見的這種或那種混亂的根源。

考慮以下示例代碼片段:

function clearBoard(){
  alert("Cleared");
}
document.addEventListener("click", function(){
  this.clearBoard(); // 這個 "this" 是什么?
});

如果執行上述代碼,然后單擊該頁面,則會導致以下錯誤“ Uncaught TypeError:this.clearBoard not a function”。原因是正在執行的匿名函數是在文檔的上下文中,而 clearBoard 是在 window 中定義的。

傳統的、與舊瀏覽器兼容的解決方案是簡單地將對它的引用保存在一個變量中,然后閉包可以繼承這個變量。例如:

var self = this;
document.addEventListener("click", function(){
  self.clearBoard();
});

另外,在較新的瀏覽器中,可以使用 bind() 方法傳遞正確的引用:

document.addEventListener("click",this.clearBoard.bind(this));

7. Uncaught RangeError: Maximum call stack

這是 Chrome 瀏覽器在幾種情況下出現的錯誤,一種是調用不終止的遞歸函數。你可以在 Chrome 開發者控制臺中對此進行測試。

如果將值傳遞給超出范圍的函數,也可能會發生這種情況。許多函數的輸入值僅接受特定范圍的數字,例如,Number.toExponential(digits)Number.toFixed(digits) 接受0到20之間的數字,而Number.toFixed(digits) 接受1到21之間的數字。

var a = newArray(4294967295);  //OK
var b = newArray(-1); //range error


var num = 2.555555;
document.writeln(num.toExponential(4));  //OK
document.writeln(num.toExponential(-2)); //range error!


num = 2.9999;
document.writeln(num.toFixed(2));   //OK
document.writeln(num.toFixed(25));  //range error!


num = 2.3456;
document.writeln(num.toPrecision(1));   //OK
document.writeln(num.toPrecision(22));  //range error!

8. TypeError: Cannot read property ‘length’

這是 Chrome 瀏覽器中發生的錯誤,因為讀取undefined的變量的length屬性,你可以在 Chrome 開發者控制臺中進行測試。

通常情況下,你可以在數組上找到定義的長度,但如果數組沒有初始化或者變量名被隱藏在其他上下文中,你可能會遇到這個錯誤。通過以下示例讓我們了解此錯誤。

var testArray= ["Test"];
function testFunction(testArray) {
    for (var i = 0; i < testArray.length; i++) {
      console.log(testArray[i]);
    }
}
testFunction();

當你聲明一個帶參數的函數時,這些參數就變成了局部參數。這意味著即使你具有名稱為 testArray 的變量,函數內具有相同名稱的參數仍將被視為局部參數。

你可以通過兩種方式解決問題:

刪除函數聲明語句中的參數(事實證明,你想訪問那些在函數外部聲明的變量,因此你不需要為函數使用參數)

var testArray = ["Test"];


/* 前置條件:在函數外部定義testArray */
function testFunction(/* No params */) {
   for (var i = 0; i < testArray.length; i++) {
     console.log(testArray[i]);
   }
}


testFunction()

調用函數,將我們聲明的數組傳遞給它。

var testArray = ["Test"];


function testFunction(testArray) {
  for (var i = 0; i < testArray.length; i++) {
     console.log(testArray[i]);
   }
}


testFunction(testArray);

9. Uncaught TypeError: Cannot set property

當我們嘗試訪問未定義的變量時,它總是返回 undefined,我們無法獲取或設置任何 undefined 屬性。在這種情況下,應用程序將引發“ Uncaught TypeError:Cannot set property”。

如果 test 對象不存在,則錯誤將引發“ Uncaught TypeError:Cannot set property”。

10. ReferenceError: event is not defined

當您嘗試訪問undefined 或超出當前范圍的變量時,將引發此錯誤。你可以在Chrome瀏覽器中非常輕松地對其進行測試。

如果你在使用事件處理系統時收到這個錯誤,請確保你使用傳入的事件對象作為參數。IE 等較舊的瀏覽器會提供全局變量事件,而 Chrome 會自動將事件變量附加到處理程序。 Firefox 不會自動添加它。jQuery 之類的庫試圖規范這種行為,盡管如此,最好還是使用傳遞給事件處理程序函數的方法。

document.addEventListener("mousemove", function (event) {
  console.log(event);
})

到此,關于“JavaScript錯誤的經典問題有哪些”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

改则县| 高邮市| 桃园市| 杭锦后旗| 丰镇市| 准格尔旗| 克拉玛依市| 淮滨县| 宣汉县| 菏泽市| 临洮县| 墨竹工卡县| 铁岭县| 射阳县| 英山县| 留坝县| 江川县| 东宁县| 浦江县| 青田县| 汶川县| 西吉县| 阿合奇县| 集贤县| 阜南县| 长春市| 彭阳县| 黄梅县| 依兰县| 策勒县| 大悟县| 浦江县| 游戏| 桂平市| 自贡市| 崇仁县| 长丰县| 库伦旗| 商洛市| 平安县| 台南县|