インストールプロセスには入りません。成功した場合は、node コマンドを使用できます。 Node.js のデバッグは非常に便利です。各バックエンド言語には、ダーク コンソール グループに出力する実用的なコマンドがあります。 node.js は、FF のセット、つまりコンソール オブジェクトとそのメソッドに従います。まず、次の内容を含む example.js ファイルを作成し、それをコンソールで開きます。
console.log("hello node.js ")
for(var i in console){
console.log(i " " console[i])
}
node example.js。
node.js のデバッグには、alert を使用しないでください。これはブラウザーが提供するグローバル メソッドです。エラーが報告されないのはおかしいでしょう。
出力結果は次のとおりです:
var log = function () {
process.stdout.write(format.apply(this, argument) 'n');
}
var info = function () {
process.stdout .write(format.apply (this, argument) 'n');
}
var warn = function () {
writeError(format.apply(this, argument) }
var error = function () {
writeError(format.apply(this, argument) 'n');
}
var dir = function (object) {
var util = require('util' );
process.stdout.write(util.inspect(object) 'n');
}
var time = function (label) {
times[label] = Date.now() ;
}
var timeEnd = function (label) {
var period = Date.now() - 回
exports.log('未定義: NaNms ', label, period) ;
}
var trace = function (label) {
//
// が公開されたら、おそらく TODO は V8 のデバッグ オブジェクトを使用してより適切に実行できるでしょう。 >var err = 新しいエラー ;
err.name = ラベル ||
Error.captureStackTrace(err, argument.callee); error(err.stack) ;
}
varassert = function (expression) {
if (!expression) {
var arr = Array.prototype.slice.call(arguments, 1);
require('assert').ok(false, format.apply(this, arr));
}
}
これらの関数を通じて、そのノードを大まかに理解します。 .js はグローバル スコープにあります。 require や process など、追加されたもの。ただし、一定範囲の私的オブジェクトである可能性があるため、恣意的に言うことはできません。ただし、これらのグローバル オブジェクトを理解し、これらのオブジェクトから他のオブジェクトを理解することは、node.js の生態学的構造を理解するのに非常に役立ちます。フロントエンドでは、ブラウザがアップグレードされるたびに、ウィンドウ オブジェクトとその要素ノードを走査して追加されたメソッドと属性を確認し、ドキュメントを確認します。これらの変更ログからすべての詳細を知ることは不可能です。他の人よりも詳しく知るためには、自分で確認する必要があります。さて、node.js のグローバル オブジェクトを見つけてみましょう。
node.js のドキュメントには、次のグローバル オブジェクトがあることが記載されています:
global, process, require,__filename,__dirname, module
コードをコピーします
結果は次のようになります:
コードをコピー
var Buffer = function Buffer(subject, encoding, offset) {
//長すぎるため、
を省略します }
var setTimeout = function () {
var t = NativeModule.require('timers');
return t.setTimeout.apply(this, argument); >}
var setInterval = function () {
var t = NativeModule.require('timers');
return t.setInterval.apply(this, argument); clearTimeout = function () {
var t = NativeModule.require('timers');
return t.clearTimeout.apply(this, argument);
var clearInterval = function () {
var t = NativeModule .require('timers');
return t.clearInterval.apply(this, argument);
}
var console = [オブジェクト オブジェクト]
グローバルには、ブラウザウィンドウと同様に、それ自体を指す同じ名前のメンバーがあることがわかります。ウィンドウ === ウィンドウ.ウィンドウ、グローバル === グローバル.グローバル。ただし、node.js は初期の段階では適切に設計されておらず、別の冗長な GLOBAL メンバーが作成されました。
console.log(global === global.global)//true
console.log(global === global.GLOBAL)//true
次にモジュール オブジェクトをスキャンします:
for(var i in module){
console。 log("var " i " = " module[i])
}
結果は次のようになります:
var id = .
var exports = [object Object]
varparent = null
var filename = /home/cheng19840218/node/example.js
var ロード = false
var exited = false
var Children =
var paths = /home/cheng19840218/node/node_modules,/home/cheng19840218 /node_modules,/home/node_modules,/node_modules
varload = function (filename) {
//長すぎるため省略
}
var _compile = function (content, filename) {
//長すぎるので省略します
}
有名なエクスポートがここで提供されていることがわかり、__filename はおそらく filename への参照です。ざっと読んでみると、たくさんの興味深いことがわかります。しかし、秘密がすぐに暴露されるとは思わないでください。まだ通過できない属性がたくさんあります。たとえば、上記のグローバル オブジェクトを調べましたが、数えることができるメンバーは少数です。ecma262v5 の新しいメソッドを使用して確認できます。
console.log(Object.getOwnPropertyNames(global))
結果は次のとおりです。
[ 'clearInterval',
'TypeError'、
'decodeURI'、
'Buffer'、
'parseFloat'、
'Number'、
'URIError'、
'encodeURIComponent'、
'RangeError'、
'ReferenceError'、
'RegExp'、
'Array'、
'isNaN'、
'setTimeout'、
'console'、
'日付'、
' 無限大'、
'ブール'、
'エラー'、
'ルート'、
'NaN'、
'文字列'、
' Function'、
'Math '、
'未定義'、
'encodeURI'、
'escape'、
'unescape'、
'process'、
'decodeURIComponent '、
'EvalError' 、
'clearTimeout'、
'GLOBAL'、
'setInterval'、
'SyntaxError'、
'Object'、
'eval' ,
'global',
'parseInt',
'JSON',
'isFinite' ]
多くの人は、node.js を学習し、すぐにドキュメントを読みます。 Node.js 自体が依存していることはほとんど知られていません。V8 エンジンには、ecma262v5 によってもたらされた新しいメソッドやオブジェクト、Firefox を模倣する構文など、学ぶべきことがたくさんあります。
__defineGetter__
__defineSetter__
__lookupGetter__
__lookupSetter__
set
get
__proto__
ただし、set や get などの最新のブラウザー (IE9 など) ではこれをサポートすることはお勧めしません。以下の開発者ツールで試すことができます:
var a = {
get 最新 () {
if (this.log.length > 0) {
return this.log[this.log.length - 1]; }
else {
return null ;
}
},
log: []
}
a.log[0] = "a"; .log[1] = "b";
console.log(a.latest)
基本的に、node.js には互換性の問題はありません (初期のノードからプレイしていない場合) .js)、非常に多くのネイティブ オブジェクトが追加されており、node.js に付属のライブラリと組み合わせて、各モジュールがさまざまな API を提供しています。それだけでは不十分な場合は、github に何千ものプラグインがあります。これは、バックエンド プログラミングに挑戦したい JSers にとって非常に魅力的です。バックエンドにはデータベース操作が含まれるのではないかと言う人もいるかもしれません。これは、フロントエンドの DOM 互換性に比べれば何でもありません。他のフォルダーやファイルの操作については、特別な配列操作として扱ってください。だからあなたは怒られるかもしれません!
var http = require("http");
http.createServer(function(request, response) {
response.writeHead(200, {"Content-Type": "text/plain) "});
response.write("Hello node.js");
response.end();
}).listen(8888);
ノード。 js には特別な require があり、他のモジュールからオブジェクトを同期的に読み込むために使用されます。これは、他の言語の require および import に似ています。フロントエンドと違ってレイヤーごとに同期できると良いですね。次に、関数を使用してサーバー オブジェクトをインスタンス化し、ポート 8888 をリッスンします。これは、node.js 公式 Web サイトにあるオリジナルの例ですが、誰もがそれを悪く書いています。しかし、そのようなプログラムは実際には役に立ちません。アドレス バーに URL を入力するときは、少なくとも完全なページを私に返さなければなりません。
このためには、まずモジュール化する必要があります。モジュール化はファイルに基づいて行われます。example.js の名前をserver.js に変更し、内部のコンテンツをモジュールに変更します。 node.js ファイルの場合、ファイル内のコンテンツは実際には閉じられた環境で実行されます。他のモジュールと共有したい場合は、exports オブジェクトにバインドする必要があります。
var http = require("http") ;
exports.start = function(){
http.createServer(function(request, response) {
console.log("リクエストを受信しました...");
response.writeHead(200) , {" Content-Type": "text/plain"});
response.write("Hello node.js");
response.end()
}); ;
console.log("server start...");
}
次に、入り口として別のindex.jsを構築します(index.jsとserver.jsが配置されています)同じディレクトリ内)。
var server = require("./server ");
server.start();
次に、index.html ページを作成します。
>
これはホームページです
このページが出てきてユーザーに返します。今回はfsモジュール方式を使用します。
コードをコピー
fs.readFile('./index) .html' , 'utf-8',function (err, data) {//Read content
if (err) throw err;
response.writeHead(200, {"Content-Type": "text/ html" }); //ここに注意してください
response.write(data);
response.end();
});
}).listen(8888);
コンソール。 log( "server start...");
}
それでは、再起動してアドレスを再度入力すると、完全なページが表示されます。
しかし、HTML 構造層に加えて、ページには JavaScript と CSS も含まれています。次に、現在のディレクトリに javascripts フォルダーを作成し、その中にindex.js を作成します。内容は次のとおりです。
コード
}
別のstylesディレクトリを作成し、その中にindex.cssを作成します。内容は次のとおりです:
コードをコピーします
次に、index.html に次の 2 つのファイルを導入します。
コードをコピーします

Vercel是什么?本篇文章带大家了解一下Vercel,并介绍一下在Vercel中部署 Node 服务的方法,希望对大家有所帮助!

gm是基于node.js的图片处理插件,它封装了图片处理工具GraphicsMagick(GM)和ImageMagick(IM),可使用spawn的方式调用。gm插件不是node默认安装的,需执行“npm install gm -S”进行安装才可使用。

如何用pkg打包nodejs可执行文件?下面本篇文章给大家介绍一下使用pkg将Node.js项目打包为可执行文件的方法,希望对大家有所帮助!

本篇文章带大家详解package.json和package-lock.json文件,希望对大家有所帮助!

本篇文章给大家分享一个Nodejs web框架:Fastify,简单介绍一下Fastify支持的特性、Fastify支持的插件以及Fastify的使用方法,希望对大家有所帮助!

node怎么爬取数据?下面本篇文章给大家分享一个node爬虫实例,聊聊利用node抓取小说章节的方法,希望对大家有所帮助!

本篇文章给大家分享一个Node实战,介绍一下使用Node.js和adb怎么开发一个手机备份小工具,希望对大家有所帮助!

先介绍node.js的安装,再介绍使用node.js构建一个简单的web服务器,最后通过一个简单的示例,演示网页与服务器之间的数据交互的实现。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

ドリームウィーバー CS6
ビジュアル Web 開発ツール

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境
