ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScriptの知識ポイント集_JavaScriptスキル

JavaScriptの知識ポイント集_JavaScriptスキル

WBOY
WBOYオリジナル
2016-05-16 15:26:491111ブラウズ

JavaScript は、型のサポートが組み込まれた、動的に型付けされた弱い型付けのプロトタイプベースの言語です。そのインタプリタは JavaScript エンジンと呼ばれ、ブラウザの一部であり、クライアント側のスクリプト言語で広く使用されています。これは、HTML Web ページに動的機能を追加するために HTML (標準ユニバーサル マークアップ言語に基づくアプリケーション) で最初に使用されました。 。

まず、より公式なテキスト記述を使用して JavaScript を説明しましょう:

JavaScript は、型のサポートが組み込まれた、動的に型付けされた弱い型付けのプロトタイプベースの言語です。
そのインタプリタは JavaScript エンジンと呼ばれ、ブラウザの一部であり、クライアント側のスクリプト言語で広く使用されています。最も古いものは
です。 HTML (Standard Universal Markup Language に基づくアプリケーション) Web ページで使用され、HTML Web ページに動的機能を追加します。

JavaScript には次の特徴があります:

・スクリプト言語。 JavaScript は解釈されるスクリプト言語です。C や C++ などの言語は最初にコンパイルされてから実行されますが、JavaScript はプログラムの実行中に 1 行ずつ解釈されます。
· オブジェクトベース。 JavaScript はオブジェクトベースのスクリプト言語であり、オブジェクトを作成するだけでなく、既存のオブジェクトを使用することもできます。
・ 単純。 JavaScript 言語は、弱い型指定の変数型を使用し、使用されるデータ型に厳密な要件を課しません。Java の基本的なステートメントとコントロールに基づいたスクリプト言語であり、その設計はシンプルでコンパクトです。
· ダイナミック。 JavaScript は、Web サーバーを経由せずにユーザー入力に応答できるイベント駆動型のスクリプト言語です。 Web ページにアクセスしているときに、マウスがクリックされたとき、上下に移動したとき、またはウィンドウ内で移動したとき、JavaScript はこれらのイベントに直接応答できます。
· クロスプラットフォーム。 JavaScript スクリプト言語はオペレーティング システムに依存せず、ブラウザーのサポートのみが必要です。したがって、JavaScript スクリプトを作成した後、マシン上のブラウザが JavaScript スクリプト言語をサポートしていれば、そのスクリプトを任意のマシンに持ち込んで使用できます。現在、JavaScript はほとんどのブラウザでサポートされています。

JavaScript は次の部分で構成されます:

・ECMAScript、言語の構文と基本オブジェクトを記述します。
· ドキュメント オブジェクト モデル (DOM)。Web コンテンツを処理するためのメソッドとインターフェイスを記述します。
· ブラウザ オブジェクト モデル (BOM)。ブラウザと対話するためのメソッドとインターフェイスを記述します。

JavaScript にはどのようなデータ型がありますか?

・オブジェクト object には、関数、文字列、配列、オブジェクト、日付などが含まれます。
· 文字列
· 番号
· ブール値
· null
· 未定義

コードの次の部分は上記のことを証明します:

文字列と数値はオブジェクトであり、文字列と数値は異なるデータ形式です...

var str = "abc";
var Str = new String("abc");
var num = 100;
var Num = 新しい数値(100);
console.log(typeof str, typeof Str, typeof num, typeof Num); // 文字列オブジェクト番号 object

オブジェクト プロトタイプ チェーンとは何ですか?

新しいオブジェクト (コンストラクターを使用して作成) を使用するか、Object.create を使用してオブジェクトを作成すると、オブジェクトにはプロトタイプとプロトタイプ チェーンが含まれます。
例: コンストラクター _obj を作成し、その後 _obj を使用して新しい obj を作成します。このときのプロトタイプ チェーンは、obj → _obj → Object.prototype → null となります。

コードを通して説明してみましょう:

 function _obj(){};
 _obj.prototype.name = "野兽"; //每个函数都包含一个prototype属性,这个属性指向一个对象的引用,这个对象就是“原型对象”。
 _obj.prototype.age = 21;
 _obj.prototype.sayHello = function(){
   console.log("Hello "+this.name);
 };
 var obj = new _obj();
 console.log(obj); //_obj{} 而其的__proto__里包含了_obj里的各个属性,包括name,age,sayHello 
 console.log(obj.__proto__ == _obj.prototype); //true
 obj.sayHello(); // Hello 野兽
 console.log(Object.prototype.__proto__); // null 当我们追究到Object(也就是object的源头时)其指向的是null 

Object.create(null) のプロトタイプ チェーンは直接 null であることに注意してください。これは、プロトタイプ チェーンが非常に短いことを意味します...

JavaScript でスコープを操作するにはどうすればよいですか?

JavaScript で var を使用して変数を宣言すると、実際にはスコープが指すオブジェクトに属性と属性値を追加することになります。
JavaScript にはブロックレベルのスコープはありません。現在のスコープで宣言された変数は現在のスコープ内でのみ使用でき、関数内で宣言された関数は関数内でのみ使用できます (操作が実行されない場合)。関数の外でこの変数を呼び出すと、定義されていないエラーが報告されます。

スコープを理解するためにコードを実行してみましょう:

 var firstNum = 1;
 ~function(){
   var secondNum = 2;
   console.log("在里面打印:"+firstNum ,secondNum); // 在里面打印:1 2
 }();
 console.log("在外面打印:"+firstNum ,secondNum); // Uncaught ReferenceError: secondNum is not defined(…) 

スコープにはスコープ チェーンもあります:

 var firstNum = 1;
 console.log("在最外层打印:"+firstNum); // 在最外层打印:1
 ~function(){
   var secondNum = 2;
   console.log("在中间层打印:"+firstNum,secondNum); // 在中间层打印:1 2
   ~function(){
     var thirdNum = 3;
     console.log("在最里层打印:"+firstNum,secondNum,thirdNum); // 在最里层打印:1 2 3
   }();
   console.log("在中间层打印:"+firstNum,secondNum,thirdNum); // Uncaught ReferenceError: thirdNum is not defined(…)
 }();
 console,log("在最外层打印:"+firstNum,secondNum,thirdNum); // 由于上面已经报错,而浏览器执行JavaScript又是单线程的,所以压根没执行到这句... 

言い換えると、現在のスコープで宣言された変数はそのサブスコープでも引き続き使用できます。これは素晴らしいことです (笑)。

クロージャとは何ですか?遊び方は?

関数の実行は変数のスコープに依存します。このスコープは関数の呼び出し時ではなく、関数の定義時に決定されます。この種の字句スコープを実現するには、JavaScript 関数オブジェクトの内部状態に関数の論理コードが含まれるだけでなく、現在のスコープ チェーンも参照する必要があります。関数オブジェクトはスコープ チェーンを通じて相互に関連付けることができ、関数本体内の変数を関数のスコープに格納できます。この機能は実際には「クロージャ」です。
引き続きコードを見てみましょう:

function counter(){
  var num = 0;
  return {
   count : function(){ return num++; },
   reset : function(){ return num = 0; }
  }
 };
 var firstNum = counter();
 var secondNum = counter();
 console.log(firstNum.count()); // 0
 console.log(secondNum.count()); // 0
 firstNum.reset();
 console.log(firstNum.count()); // 0 num已被重置,所以返回的为0
 console.log(secondNum.count()); // 1 num未被重置,所以返回的是1
 console.log(firstNum,secondNum); // 都为 Object{ count:function(),reset:function(),__proto__} 并且并不能在其中找到counter里var的n,这也实现了函数里的私有变量,只将需要暴露的两个方法给暴露在外。 

闭包用的多的两个作用:读取函数内部的变量值;让这些变量值始终保存着(在内存中)。
同时需要注意的是:闭包慎用,不滥用,不乱用,由于函数内部的变量都被保存在内存中,会导致内存消耗大。

JavaScript中的this

在JavaScript中,this通常指向的是我们正在执行的函数本身,或者是,指向该函数所属的对象。

全局的this → 指向的是Window
函数中的this → 指向的是函数所在的对象
对象中的this → 指向其本身

验证代码:

 console.log(this); // Window {external: Object, chrome: Object, document: document, global: Window, cr: Object…} 全局下执行console.log,所以此处指向的是Window
 ~function seeThis(){
  console.log(this); // Window {external: Object, chrome: Object, document: document, global: Window, cr: Object…} 由于我是在全局下写的这个函数,所以此处指向的还是Window
 }();
 var obj = {
  name:"野兽",
  showThis:function(){
   console.log(this); // Object {name: "野兽",showThis:function(),__proto__} 此处打印的是对象本身
  }
 };
 obj.showThis(); 

arguments

在Javascript函数体内,arguments像数组一样(并不是真的数组),有length属性,可以代表传给函数的参数的个数。

简单来说,arguments函数执行时所传的实际参数。
比如:arguments[0]表示传入第一个参数。

用代码验证

 function argumentsTest(){
  console.log(arguments[0]?arguments[0]:"Hello World",arguments[1]?arguments[1]:"你好 世界")
 };
 argumentsTest(); // Hello World 你好 世界
 argumentsTest("This is firstValue => arguments[0].","This is secondValue => arguments[1]."); // This is firstValue => arguments[0]. This is secondValue => arguments[1]. 

好了,关于javascript知识点先给大家整理这么些,全当温习下知识点,本文写的不好,还望各位朋友多多指教。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。