ホームページ > ウェブフロントエンド > jsチュートリアル > 私の JavaScript 関数が jsfiddle.net で見つからないのはなぜですか?

私の JavaScript 関数が jsfiddle.net で見つからないのはなぜですか?

Susan Sarandon
リリース: 2024-10-30 22:06:29
オリジナル
809 人が閲覧しました

Why Can't My JavaScript Functions Be Found on jsfiddle.net?

jsfiddle.net で JavaScript コードが失敗する理由

提供されたコードは、jsfiddle.net で実行しようとすると問題が発生し、コンソールに「ReferenceError: Function Name」が記録されます。定義されていません。」これを理解するために、コードの構造を詳しく調べ、jsfiddle 内での実行を分析します。

このコードでは、BetterSelectfillList などの関数が関数内で定義されています。 window.onload。一般的な Web 環境では、この関数により、ウィンドウが読み込まれた後にコードが確実に実行されます。ただし、jsfiddle のフレームワーク内では、この側面に重要な違いが導入されています。

コードがライブ サイトで実行される場合、関数は特定の関数スコープの外で定義されているため、ウィンドウ オブジェクト内でグローバルに使用できます。ただし、jsfiddle では、関数は window.onload 関数のスコープ内でのみアクセスできます。

この問題にはいくつかの解決策があります。

  1. 関数のグローバル定義: 関数の宣言を window.functionName = function(){};.
  2. に変更します。目立たない JavaScript: HTML を JS から分離して、JS のみを介して DOM 要素に動作を付加します。
  3. jsfiddle のデフォルト ラッピングを無効にする: 「onLoad」の代わりに「No Wrap」(ボディまたはヘッド) を選択します。

このスコープの問題に対処することで、両方のライブ サイトで JavaScript コードが正しく実行されるようにすることができます。と jsfiddle.net.

以上が私の JavaScript 関数が jsfiddle.net で見つからないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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