學(xué)習(xí)筆記-0805-nodejs

前一日知識點(diǎn)回顧

提問:markdown如何生成目錄
怎樣做筆記,筆記用markdown格式編寫
全棧工程師需要掌握的技能
不同編程語言的區(qū)別
函數(shù)編程和指令編程的差異
指令式編程需要我們像計(jì)算機(jī)一樣思考
函數(shù)編程希望計(jì)算機(jī)像人一樣思考
java8
ruby原作者是日本人,美國人推廣壯大
每天兩個助教老師檢查大家的作業(yè)
作業(yè)晚上交,筆記早上交

今日訓(xùn)練重點(diǎn)

在指令式編程模式下完成軟件設(shè)計(jì)
目標(biāo):培養(yǎng)大家像計(jì)算機(jī)一樣思考
javascript:
使用的語言和我要做的開發(fā)工作沒有太大關(guān)系

js在兩個不同 模式下的工作
交互模式:node -v v4.4.7
命令行模式

var printStr="";
printStr +="*"
console.log(printStr);

算法題 要摸清題的思路,找到算法規(guī)律,計(jì)算機(jī)擅長做重復(fù)性工作

指令式編程:程序一般是從上到下,但是可以通過條件判斷來執(zhí)行對應(yīng)的代碼段;

指令式編程思想:要求思維清晰,代碼完整(添加注釋) 顯示效果美觀

培養(yǎng)抽象的能力,抽象是總結(jié)規(guī)律的思維方式

console.log('*'); //打印輸出

實(shí)例:

  1. 通過循環(huán)解決重復(fù)性工作
var printStr = ""; //定義字符
for (var i=0;i<10;i++){ //使用for循環(huán)拼接字符串
  printStr +="*";
}
console.log(printStr);//打印輸出

2.循環(huán)輸出多行

var printStr = ""; //定義字符
for (var j=0;j<5;j++){  //使用for循環(huán)輸出5行
  for (var i=0;i<10;i++){ //使用for循環(huán)拼接字符串
    printStr +="*";
  }
  printStr +="\n"; //換行符
}
console.log(printStr);//打印輸出

3.封裝函數(shù)

var printStr = ""; //定義字符
function getStr(m,n,p){ //m行數(shù),n每行的字符長度,p定義字符格式
  for (var j=0;j<m;j++){  //使用for循環(huán)輸出m行
    for (var i=0;i<n;i++){ //使用for循環(huán)拼接字符串
      printStr +="p";
    }
    printStr +="\n"; //換行符
  }
}
getStr(5,10,"*");
  console.log(printStr);//打印輸出

輸出結(jié)果:


2.pic.jpg

4.功能抽象,細(xì)化

//定義默認(rèn)的輸出字符串
var printStr = '';

//打印行
function printRow(num,cont){
    //循環(huán)拼接輸出一行字符串
    for(var i=0;i<num;i++){
        printStr += cont;
    }
}

//換行的函數(shù)
function br(){
    //當(dāng)輸出一行就換行
    printStr += "\n";
}
//打印矩形
function printShape(r,c){
    for(var j=0;j<r;j++){
        //打印行
        printRow(c,'*');
        //輸出一行后就換行
        br();
    }
}
//調(diào)用printSharp函數(shù)  5行10列
printShape(5,10);

//打印輸出
console.log(printStr);

輸出結(jié)果:


2.pic.jpg

5.打印更多形狀

  • 封裝打印正方形函數(shù)
//打印正方形
function printSquare(m){
  printShape(m,m);
}
printSquare(10);
//打印輸出
console.log(printStr);
  • 打印空心矩形
printRow(20,"*");
br();
printRow(1,"*");
printRow(18," ");
printRow(1,"*");
br();
printRow(1,"*");
printRow(18," ");
printRow(1,"*");
br();
printRow(1,"*");
printRow(18," ");
printRow(1,"*");
br();
printRow(1,"*");
printRow(18," ");
printRow(1,"*");
br();
printRow(20,"*");
br();
//打印輸出
console.log(printStr);

輸出結(jié)果:


3.pic.jpg
  • 封裝打印空心矩形函數(shù)
//行數(shù)r=5,列數(shù)l=10,字符cont="*"
//第一行和第r行完全輸出
//第2行到第r-1行輸出空虛
//空字符串長度l-2
//輸出空心矩形
function getEmptyShape(r,l,cont){

    //判斷行數(shù)或者列數(shù)是否小于等于2,如果小于直接輸出
    if (r<=2 || l<=2) {
        for (var i = 1;i<=r;i++) {
            printRow(l,cont);
            br();
        }
    }else{
    //行數(shù)和列數(shù)大于2的情況,輸出空心矩形
        for (var i = 1; i <= r; i++) {
            if (i==1 || i == r){
                printRow(l,cont);
                br();
            }else{
                printRow(1,cont);
                printRow(l-2," ");
                printRow(1,cont);
                br();
            }
        }
    }           
}
//多測試幾種情況,檢驗(yàn)函數(shù)是否有bug
getEmptyShape(1,1,"*");
br();
getEmptyShape(2,1,"*");
br();
getEmptyShape(1,2,"*");
br();
getEmptyShape(1,3,"*");
br();
getEmptyShape(2,3,"*");
br();
getEmptyShape(5,10,"*");

//打印輸出
console.log(printStr);

輸出結(jié)果:


4.pic.jpg
  • 打印實(shí)心三角形
printRow(5," ");
printRow(1,"*");
br();
printRow(4," ");
printRow(3,"*");
br();
printRow(3," ");
printRow(5,"*");
br();
printRow(2," ");
printRow(7,"*");
br();
printRow(1," ");
printRow(9,"*");
br();
//打印輸出
console.log(printStr);

輸出結(jié)果:


7.pic.jpg
  • 封裝打印三角形函數(shù)
//輸出三角形,r行數(shù),cont="*"
function getTriangle(r,cont){
    for (var i = r; i >0; i--) {
        printRow(i," ");
        printRow((r-i)*2+1,cont);
        br();
    }
}
getTriangle(5,"*");
//打印輸出
console.log(printStr);

輸出結(jié)果:


7.pic.jpg
  • 封裝打印梯形函數(shù)
//輸出梯形,r行數(shù),cont="*"
function getTrapezium(r,cont){
    if (r>1) {
        for (var i = r-1; i >=0; i--) {
            printRow(i," ");
            printRow((r-i)*2+1,cont);
            br();
        }
    }else{
        printStr += "梯形至少需要2行";
    }
}
getTrapezium(5,"*");
//打印輸出
console.log(printStr);

輸出結(jié)果:

6.pic.jpg

作用域

  • js無命名空間,同一個變量名不能申明兩次
  • 變量作用域:局部變量 全局變量命名不沖突
  • 最外層目錄申明一個變量a 可以用window.a = 5 ;其與var a = 5一樣;
  • 當(dāng)程序內(nèi)部找不到定義的變量,就去上層目錄找,直到頂層目錄
  • nodes中全局變量用global
//var num 是一個局部變量
//變量函數(shù)
var returnFun = function(){
}
function f(){
  return function(){
  }
}

var x = f();
//x就等于f函數(shù)的內(nèi)部函數(shù)
  • 函數(shù)大口號后面再加一個括號表示直接執(zhí)行

     //立即執(zhí)行的函數(shù)
    (function(){
      var num = 10;
    })();
    

作業(yè):
1.抽象一個打印空心矩形的函數(shù),打印梯形的函數(shù),三角形的函數(shù) 打印空心梯形 空心三角形的函數(shù)
2.node.js在linux環(huán)境更好一些,每個人ubuntu16.04安裝一個node.js,能夠上網(wǎng) 獨(dú)立ip

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,062評論 25 709
  • 指令式編程 培養(yǎng)指令式編程思維 復(fù)習(xí)上一節(jié)課的內(nèi)容 Markdown是一種輕量級的「標(biāo)記語言」,使用它來書寫文檔、...
    Junting閱讀 659評論 0 1
  • 郭相麟 人生路上 一段邂逅在交流中 拉開愛的序幕 心靈的碰撞 思想的互動 演繹著刻骨銘心的情意 或許有緣無份 或許...
    郭相麟閱讀 228評論 0 0
  • (原創(chuàng)文章,轉(zhuǎn)載請注明出處) 朗誦文稿: 一首寫給大埔的情詩 /王斯禪 2017.11.22 嘿!鄉(xiāng)親,今夜我要告...
    斯禪閱讀 944評論 1 3
  • 老實(shí)說,應(yīng)該沒有人會覺得自己的智商是夠用的,因?yàn)橹巧烫匾耍〔还苁欠N間競爭還是種內(nèi)競爭,智商都是人的核心競爭力。...
    湘瑋閱讀 528評論 1 2

友情鏈接更多精彩內(nèi)容