理解腳本
JavaScript 是一門動態類型、面向對象的腳本語言。
腳本原本出自戲劇舞臺,主要由人物對話和舞臺提示構成,演員和道具組只需要按照腳本寫的做即可。
編程領域的腳本也類似,計算機只要按照腳本上寫的運行即可。
簡而言之,腳本就是給計算機照著做的。
例如:
cd ~/Desktop
mkdir demo
cd demo
echo 'hi' > index.html
cd ~/Desktop
寫一個腳本
- 新建目錄、文件
mkdir ~/local
cd ~/local
touch demo.sh
- 編輯 demo.sh ,寫入以下代碼,exit 寫不寫都會退出
(MacOS/Linux 會自動運行,可以修改后綴mv demo.sh demo.txt
)
mkdir demo
cd demo
mkdir css js
touch index.html css/style.css js/main.js
exit
- 給 demo.sh 添加執行權限,x 的意思是可執行 (Windows用戶跳過這一步)
chmod +x demo.sh
- 在任意位置執行,會多出一個 demo 目錄和一些文件,這個 demo.sh 就是一個Bash 腳本
cd ~/Desktop
sh ~/local/demo.sh
- 將 ~/local 添加到 PATH
獲取 local 目錄的絕對路徑,pwd 可以獲取當前目錄絕對路徑
cd ~/local; pwd
臨時設置 PATH(重啟 Bash 后就會失效)
a. 把目錄 local 加到 PATH
export PATH="local的絕對路徑:$PATH"
b. 這樣,運行 demo.sh 就等于運行 sh ~/local/demo.sh
了(不用管 File exists 的報錯)
永久設置 PATH
a. 創建 ~/.bashrc
touch ~/.bashrc
b. 編輯 ~/.bashrc
start ~/.bashrc
c. 在編輯器添加一行代碼:
export PATH="local 的絕對路徑:$PATH"
d. 運行
source ~/.bashrc
e. 這樣,運行 demo.sh 就等于運行 sh ~/local/demo.sh
了
- 如果你覺得 demo.sh 的后綴沒什么用,可以刪掉
mv ~/local/demo.sh ~/local/demo
PATH
PATH的作用
每次在 Bash 輸入一個命令時(比如 ls、cp、rm、demo.sh),Bash 都會去 PATH 列表里面尋找對應文件,找到了就會執行。type demo.sh
可以看到尋找過程which demo.sh
可以看到尋找結果文件后綴的作用:毫無作用
Windows 和 Linux 有一點區別,可以指定打開文件的應用程序,方便人能看懂,但是對于機器來說實際上毫無作用。Bash 的真相:所有命令都是可執行的文件,也就是說都是可執行的腳本而已。
Linux 系統內所有東西都是文件,可執行的文件就是命令,不可執行的文件就是配置。
參數
demo 腳本只能創建名字為 demo 的目錄?我們來讓目錄名是可變的吧。將前面demo.sh的內容修改:
mkdir $1
cd $1
mkdir css js
touch index.html css/style.css js/main.js
exit
$1 表示你傳的第一個參數(google bash first parameter), 然后你再輸入代碼 demo xxx 就會建立一個名為 xxx 目錄了,且包含腳本所包含的文件。Bash 的語法比較變態,記不住很正常,遇到不會的 Google 就好了。
if...else...
判斷目錄是否已存在(Google check if a directory exists in a shell script)。運用 if...else... 語句,將腳本代碼改為(注意空格、冒號不能少):
if [ -d $1 ]; then
echo 'error: dir exists'
exit
else
mkdir $1
cd $1
mkdir css js
touch index.html css/style.css js/main.js
echo 'success'
exit
fi
返回值
exit 0
表示執行成功
exit 1
表示錯誤代碼為1
demo && echo 'end'
只有在 demo 腳本成功運行時,才會執行 echo 'end'
命令1 && 命令2 的意思是,命令1運行成功后,才會運行命令2
思考題
我們創建的 index.html style.css 和 main.js 都是空文件,如何給他們填充內容呢?
Node.js 寫腳本
我們上面寫的腳本叫做 Bash Script(Bash腳本),JS 的全稱叫做JavaScript(Java腳本),雖然 JS 和 Java 沒什么關系,但依然是一種腳本,感興趣的可以參考 JavaScript誕生記
- 我們可以在 Bash 命令行里輸入 Bash 命令,也可以在 Node.js 命令行里輸入 JS 命令{ Ctrl + D 退出}
- Bash 腳本能做的事情,JS 腳本也能做。(sh demo.sh 對應 node demo.js)
用 JS 切換目錄
process.cwd() 相當于 pwd
console.log() 相當于 echo
process.chdir() 相當于 cd
打印當前目錄
console.log(process.cwd())
切換目錄
process.chdir("/Users/Administrator/Desktop/")
【process.chdir('~/Desktop')
這句話不能運行,因為JS不認識 ~ 目錄】
用 JS 腳本創建目錄
Google nodejs create dir
nodejs的file system文檔:https://nodejs.org/api/fs.html#fs_fs_mkdirsync_path_mode
fs.mkdirSync(path[,mode])
let fs = require("fs")
fs.mkdirSync("demo")
用 JS 腳本創建文件
Google nodejs create file
文檔:https://nodejs.org/api/fs.html#fs_fs_writefilesync_file_data_options
fs.writeFileSync(file,data[,options])
let fs = require('fs')
fs.writeFileSync("./index.html", "data")
補充:
nodejs英文文檔: https://nodejs.org/api
nodejs中文文檔: nodejs.cn/api
用JS腳本來重寫 demo.sh
- 創建 ~/local/jsdemo.js ,內容如下:
var fs = require('fs')
var dirName = process.argv[2] // 你傳的參數是從第2個開始的
fs.mkdirSync("./" + dirName) // mkdir $1
process.chdir("./" + dirName) // cd $1
fs.mkdirSync('css') // mkdir css
fs.mkdirSync('js') // mkdir js
fs.writeFileSync("./index.html", "")
fs.writeFileSync("css/style.css", "") // ./ 可以不寫,已經在當前目錄
fs.writeFileSync("./js/main.js", "")
process.exit(0)
- (Windows 用戶跳過這一步)給jsdemo.js 加上可執行權限
chmod + x ~/local/jsdemo.js
cd ~/Desktop
-
node ~/local/jsdemo.js test
,就可以看到 test 目錄創建成功了
shebang
我們每次執行 ~/local/jsdemo.js 都要用 node 來執行,在 jsdemo.js 第一行加上一句#!/usr/bin/env node
就可以不加 node 也能執行了
- 然后就可以直接用
~/local/jsdemo.js xxx
,省得輸入 node 了 - 如果你已經把 ~/local 加入了 PATH,就可以直接
jsdemo.js xxx
- 去掉后綴 js,就可以直接
jsdemo xxx