ホームページ > ウェブフロントエンド > jsチュートリアル > ユーザースクリプトの onclick 属性により「キャッチされない参照エラー: 関数が定義されていません」が発生するのはなぜですか?

ユーザースクリプトの onclick 属性により「キャッチされない参照エラー: 関数が定義されていません」が発生するのはなぜですか?

Susan Sarandon
リリース: 2024-11-19 06:58:02
オリジナル
374 人が閲覧しました

Why Does My Userscript's onclick Attribute Cause an

未解決の参照エラー: 関数が onclick で定義されていません

問題

ユーザースクリプトで、onclick 属性を介して関数を呼び出そうとすると、キャッチされない参照エラー: 関数はありません定義されています。

調査

関数がスクリプトで定義されている従来の onclick 属性の動作は、サンドボックス メカニズムによりユーザー スクリプトでは機能しません。

解決策

この問題を解決するには、onclick の代わりに常に addEventListener() を使用してください。

コード リファクタリング

onclick 属性を次のものに置き換えます:

document.getElementById("ElementID").addEventListener("click", functionName, false);
ログイン後にコピー

その他の懸念事項

DOM 上書きとイベント ハンドラー

innerHTML または externalHTML を使用して DOM を上書きしないでください既存のイベント ハンドラーを削除するため、要素を複数回実行します。

一意の ID

各要素に一意の ID があることを確認します。 ID を再利用すると検証の問題が発生します。

このコードでは、onclick 属性が addEventListener() に置き換えられ、DOM 上書きの問題が解決されました。

for (i = 0; i < EmoteURLLines.length; i++) {
    if (checkIMG (EmoteURLLines[i])) {
        emoteTab[2].innerHTML += '<span>
ログイン後にコピー

以上がユーザースクリプトの onclick 属性により「キャッチされない参照エラー: 関数が定義されていません」が発生するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート