JavaScript入門(mén)學(xué)習(xí)

關(guān)于JS

JS也就是JavaScript筛璧,是一種瀏覽器客戶端的腳本語(yǔ)言,給html網(wǎng)頁(yè)增加動(dòng)態(tài)功能惹恃,比如動(dòng)畫(huà)夭谤,如果想掌握好H5,JS是必須要掌握的巫糙。

JS的基本語(yǔ)法

js中朗儒,一般以var來(lái)定義一個(gè)變量,與OC不同,var定義的對(duì)象不需要指定類型醉锄,會(huì)根據(jù)對(duì)象的內(nèi)容自動(dòng)進(jìn)行判斷,如下所示乏悄。

var age = 18;  //number
var money =  1.82;//number
var name = 'Jack';//string
var  name1 = 'Rose'; //string
var result = true; //false  boolean
var score  = null;//object

而字符串的拼接也和swift一樣

//字符串拼接
//運(yùn)算時(shí)從左向右,任何類型的變量與string類型拼接都會(huì)被轉(zhuǎn)化為string
var newName = name +"-"+ name1;
var str1 = 10 + 10 + '10' + '10'; //201010
var str2 = '10' + '10' + 10 + 10; //10101010
var str3 = ('10' + 10) + "10" + 10; //10101010

那么我們一般如何調(diào)試吶,分為控制臺(tái)和提示框恳不。

//輸出 單引號(hào)雙引號(hào)都行  建議單引號(hào) 因?yàn)榘粹o是 OnClick = ""  相當(dāng)于斷點(diǎn)
alert('Hello World');
//調(diào)試輸出    谷歌瀏覽器  審查元素-console
console.log("調(diào)試輸出")
//想知道真實(shí)類型
//typeof
console.log(age,money,name,result,score);
console.log(typeof age,typeof money,typeof name,typeof result,typeof score);

數(shù)組的基本定義,數(shù)組里面可以包含數(shù)組檩小,和OC不同,數(shù)組里面可以包含不同類型的對(duì)象烟勋。

var newArr1 = [];
var newArr2 = [10, 05, age,name,result,score,['hahaha','阿薩德']]; //object
//刪除數(shù)組最后一個(gè)元素
newArr2.pop();
//數(shù)組中加一個(gè)元素
newArr2.push(['jay']);
var newNumbers = [10,-9,232,4554];
//取出最小值
var minNumber1 = Math.min(10,23,34,54);
var minNumber2 = Math.min().apply(null,newNumbers);
//取出最大值
var maxNumber = Math.max(null,newNumbers);

//輸出數(shù)組中的內(nèi)容 遍歷
for(var i = 0; i<newArr2.length; i++){
    console.log(newArr2[i]);
    }   
//這里的i是索引
for(var i in newArr2){
    console.log(i,newArr2[i]);
    }

JS的內(nèi)置對(duì)象

window 關(guān)于window有兩點(diǎn)
1.所有的全局變量都是window的屬性
2.所有的全局的函數(shù)都是window的函數(shù)

//動(dòng)態(tài)跳轉(zhuǎn)
window.location.;
location.;

JS的Dom操作

Dom的用途
Document的用途
1.動(dòng)態(tài)的獲取當(dāng)前網(wǎng)頁(yè)中的任意一個(gè)標(biāo)簽
2.動(dòng)態(tài)的獲取到的標(biāo)簽進(jìn)行crud
create retrieve update delete

//動(dòng)態(tài)插入
document.write('Hello World');
//插入標(biāo)簽
document.write('<input type = "date">');
//插入一張圖片
document.write('<img src="img/img01.png>');

DOM的curd

//c create
//增
//1
document.write('HelloWorld');
document.write('<button>')

//2
var div = document.createElement('div');
div.style.backgroundColor = 'red';
div.style.width = '500px';
div.style.height = '300px';
//添加到父標(biāo)簽
document.body.appendChild(div);
//往div中插入一張圖片
var img = document.createElement('img');
img.src = 'img/icon.png';
div.appendChild(img);

//向p標(biāo)簽插入東西
var p = document.getElementById('word');
var img2 = document.createElement('img');
img2.src = 'img/icon.png';
p.appendChild(img2);

//r retrieve
//查

//find(document.body);
//function find(object){
//  for(var i in object){
//      console.log(object[i]);
//  }
//}

console.log(document.body.childNodes);

//u update
//改
//拿到對(duì)應(yīng)的標(biāo)簽  做出改變

//d delete
//刪
//document.body.removeChild(p);
//拿到當(dāng)前標(biāo)簽的父標(biāo)簽  再來(lái)刪除
//p.parentNode.removeChild(p);
//p.remove();

JS語(yǔ)法的靈活性

 || &&
邏輯或 ||
var  name1 = 'name1';
var  name2 = 'name2';
var  name3 = 'name3';
var  name4 = 'name4';
var newName = null;
//判斷
if(name1){
    newName = name1;
    }else if(name2){
    newName = name2;
    }else if(name3){
    newName = name3;
    }else if(name4){
    newName = name4;
    }
    console.log(newName);
            
//新做法
newName = name1||name2||name3||name4;
console.log(newName);
            
//邏輯與 &&
var age = 22;
if(age>20){
    console.log('你可以結(jié)婚了');
    }
//新做法
(age>20)&&console.log('你可以結(jié)婚了!!!');

JS中的函數(shù) - 匿名函數(shù)

這就是個(gè)自己封裝的函數(shù)

//兩個(gè)數(shù)相加
function sum( number1,  number2){   
        return number1 + number2 ;
    }
//調(diào)用函數(shù)
var result =  sum(10,20);

//萬(wàn)能的加法函數(shù)
function sum2(numbers){
    var count = 0;
    for(var i = 0;i<numbers.length;i++){
        count+=numbers[i];
        }
        return count;
    }
var numbers = [10,23,46,786,97,78];
var sumResult = sum2(numbers);

//內(nèi)置數(shù)組  arguments
function sum3(){
    var count = 0;
    for(var i = 0;i<arguments.length;i++){
        count += arguments[i];
        }
        return count;
    }
var sumResult3 = sum3(10,23,46,97,78);

產(chǎn)生對(duì)象

如何自定義一個(gè)對(duì)象 帶有屬性和方法

//this this在哪個(gè)對(duì)象中就代表哪個(gè)對(duì)象
//定義一個(gè)對(duì)象
var dog  = {
        name : 'wangcai',
        age : 4,
        height : 1.2,
        friend : ['xixi','lili'],
        eat: function(something){
                console.log(this.name + '---吃' + something);
        },
        run: function(somewhere){
                console.log(this.name + '---跑' +somewhere);
        }
    };
//調(diào)用狗對(duì)象的屬性
console.log(dog.name,dog.friend);
//調(diào)用狗的方法
dog.eat('骨頭');
dog.run('公園');


//如何批量產(chǎn)生對(duì)象
//構(gòu)造函數(shù)
function Dog(){
    this.name = null;
    this.height = null;
    this.frirens = [];
    this.age = null;
    this.eat = function(something){
            console.log(this.name + '吃' + something);
            },
    this.run= function(somewhere){
            console.log(this.name + '跑' + somewhere);
            }
    }
//批量產(chǎn)生狗
var dog1 = new Dog();
var dog2 = new Dog();
//賦值
dog1.name = 'xiaohei';
dog1.height = 1.23;
dog1.run('火星');
dog1.friend = ['xiaohua'];
//賦值
dog2.name = 'xiaobai';
dog2.height = 0.53;
dog2.eat('月亮');
dog2.friend = ['xiaohuang'];

//構(gòu)造函數(shù)
function Cat(name,height,age,friends){
    this.name = name;
    this.height = height;
    this.frirens = friends;
    this.age = age;
    this.eat = function(something){
        console.log(this.name + '吃' + something);
        },
    this.run= function(somewhere){
        console.log(this.name + '跑' + somewhere);
        }
    }
//創(chuàng)建新對(duì)象
var cat = new Cat('mi',12,23,['324']);
cat.eat('貓糧');

其他

一些其他關(guān)鍵字

setTimeout("alert('時(shí)間到了')",3000);
setTimeout 在某個(gè)函數(shù)以內(nèi)執(zhí)行一個(gè)函數(shù)规求,只執(zhí)行一次
setInteger 讓程序每隔一定時(shí)間來(lái)調(diào)用函數(shù)一次

鼠標(biāo)事件

當(dāng)鼠標(biāo)進(jìn)入圖片
img.onmouseover = function(){
    alert('手指進(jìn)入圖片');
}
當(dāng)手指在圖片上移動(dòng)
img.onmousemove = function(){}
當(dāng)鼠標(biāo)移出圖片
img.onmouseout = function(){}
當(dāng)前頁(yè)面加載完畢
window.onload = function(){}

canvas 繪制圖形
這個(gè)canvas和OC中的drawRect類似

canvas 
起點(diǎn)
context.moveTo(100,100);
終點(diǎn)
context.lineTo(200,200);
繪制
context.stroke()
設(shè)置線條的顏色和寬度
context.strokeStyle = 'red';
context.lineWidth = 5;
填充
context,fillStyle = 'blue';
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市卵惦,隨后出現(xiàn)的幾起案子阻肿,更是在濱河造成了極大的恐慌,老刑警劉巖沮尿,帶你破解...
    沈念sama閱讀 216,843評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件丛塌,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡畜疾,警方通過(guò)查閱死者的電腦和手機(jī)赴邻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,538評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)啡捶,“玉大人姥敛,你說(shuō)我怎么就攤上這事〗齑龋” “怎么了徒溪?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,187評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵忿偷,是天一觀的道長(zhǎng)金顿。 經(jīng)常有香客問(wèn)我,道長(zhǎng)鲤桥,這世上最難降的妖魔是什么揍拆? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,264評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮茶凳,結(jié)果婚禮上嫂拴,老公的妹妹穿的比我還像新娘。我一直安慰自己贮喧,他們只是感情好筒狠,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,289評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著箱沦,像睡著了一般辩恼。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,231評(píng)論 1 299
  • 那天灶伊,我揣著相機(jī)與錄音疆前,去河邊找鬼。 笑死聘萨,一個(gè)胖子當(dāng)著我的面吹牛竹椒,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播米辐,決...
    沈念sama閱讀 40,116評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼胸完,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了儡循?” 一聲冷哼從身側(cè)響起舶吗,我...
    開(kāi)封第一講書(shū)人閱讀 38,945評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎择膝,沒(méi)想到半個(gè)月后誓琼,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,367評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡肴捉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,581評(píng)論 2 333
  • 正文 我和宋清朗相戀三年腹侣,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片齿穗。...
    茶點(diǎn)故事閱讀 39,754評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡傲隶,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出窃页,到底是詐尸還是另有隱情跺株,我是刑警寧澤,帶...
    沈念sama閱讀 35,458評(píng)論 5 344
  • 正文 年R本政府宣布脖卖,位于F島的核電站乒省,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏畦木。R本人自食惡果不足惜袖扛,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,068評(píng)論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望十籍。 院中可真熱鬧蛆封,春花似錦、人聲如沸勾栗。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,692評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)围俘。三九已至砸讳,卻和暖如春机断,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背绣夺。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,842評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工吏奸, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人陶耍。 一個(gè)月前我還...
    沈念sama閱讀 47,797評(píng)論 2 369
  • 正文 我出身青樓奋蔚,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親烈钞。 傳聞我的和親對(duì)象是個(gè)殘疾皇子泊碑,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,654評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容