js入門

来源:https://www.cnblogs.com/-xct/archive/2019/12/04/11984926.html
-Advertisement-
Play Games

js Brendan(布蘭登) Eich 輕量級的編程語言(ECMAscript5或6), 是一種解釋性腳本語言(代碼不進行預編譯), 主要用來向HTML頁面添加交互行為, 目前是互聯網上最流行的腳本語言, 支持面向對象、命令式和聲明式(如函數式編程)風格, JavaScript,他和Python一 ...


js

Brendan(布蘭登) Eich

輕量級的編程語言(ECMAscript5或6),
是一種解釋性腳本語言(代碼不進行預編譯),
主要用來向HTML頁面添加交互行為,
目前是互聯網上最流行的腳本語言,
支持面向對象、命令式和聲明式(如函數式編程)風格,

JavaScript,他和Python一樣是一門編程語言,而瀏覽器內置了JavaScript語言的解釋器,所以JavaScript代碼在瀏覽器上就可以運行,
DOM,(Document Object Model)是指文檔對象模型,通過它,可以操作HTML文檔的相關功能,例如:對標簽內容進行刪除和替換等(非重點),
BOM,(Browser Object Model)是指瀏覽器對象模型,通過他,可以操作瀏覽器相關的功能,例如:瀏覽器設置定時器,瀏覽器定時刷新頁面。

三種js代碼引入方式

1 head標簽的script標簽裡面(alert('xx'), confirm('xx'))

2 body標簽的script標簽裡面 (建議底部)

3 外部文件引入的方式來使用
創建一個.js結尾的文件,寫上js代碼
比如:

alert('are you ok?');

在想使用這個js代碼的html文件中,body標簽底部導入

<script src="test.js"></script>

js基礎內容(會繼續更新)

alert("daoyou");
confirm("daoyou?");

JavaScript語法規則

變數

變數定義 var a = 100;

var 變數名,,

變數聲明,但沒有賦值的時候,變數的值為undefined

數據類型

number 整數,浮點數

var n = 11;
var n2 = 11.11;

string 字元串

var a = 'abcdef';
var a = new String('ss');  

字元串操作

var s = 'hello'; 
索引取值:  s[1] -- 'e'     s.charAt(4); -- 'o' : s.substring(1,3); -- "el"

獲取長度:s.length;
移除兩端空格: s.trim();   s.trimLeft(); s.trimRight();

boolean 布爾

var a = true;
var b = false;

undefined和null類型

undefined 變數聲明瞭,但是沒有賦值,此時這個變數是undefined類型
null : 變數不用了,就可以給變數賦值為null,--- object類型

array 數組

var names = [11,22,33];

數組常用方法

names[0]    // 索引,索引也是從0開始的

names.push(ele)       // 尾部追加元素
示例:a.push('xx');       --  [11, 22, 33, "xx"]
names.pop()         // 尾部移除一個元素
示例:a.pop(); -- [11, 22, 33]
names.unshift(ele)              // 頭部插入元素
示例:a.unshift('ssss'); --  ["ssss", 11, 22, 33]
var ele = obj.shift()           // 頭部移除一個元素
示例:a.shift(); --  [11, 22, 33]    


names.splice(index,0,ele)       // 在指定索引位置插入元素
names.splice(從哪刪(索引),刪幾個(個數),刪除位置替換的新元素(可不寫,可寫多個)) 

names.splice(index,1,ele)       // 指定索引位置替換元素
names.splice(index,1)           // 指定位置刪除元素
var names = [11,22,33];
names.splice(1,1,'xx','oo','asdf'); -- [11, "xx", "oo", "asdf", 33]

names.slice(start,end)          // 切片
示例:a.slice(1,3);    

names.reverse()             // 原數組反轉
示例:a.reverse(); 

names.join(sep)             // 將數組元素連接起來以構建一個字元串
示例: var a = ['ni','hao','ma',18]
a.join('+'); -- "ni+hao+ma+18"

names.concat(val,..)        // 連接數組
示例: var a = [11,22]; var b = ['aa','bb']
var c = a.concat(b); c -- [11, 22, "aa", "bb"]

names.sort()    (辣雞)        // 對原數組進行排序  a.sort(compare); 升序排列

解決數組中數字排序的問題

a = [2,3,5,2,22,4,2,3,234,1]
function com(a,b){return a-b};    // 自定義排序規則   

a.sort(com);

當a-b大於0時,會交換數組中的這兩個元素
一直交換直到返回值沒有大於0的

字典

自定義對象Object

JavaScript中其實沒有字典類型,字典是通過對象object構造出來的

info = {
    name:'迪麗熱巴',      
    "age":18
    1:123
}

var a = {username:'xx',password:'123'}; //鍵可以不加引號 
                                     // 鍵可以是數字,但取值時必須是info["1"]
var a = info['name']/a = info.name // 通過鍵取值必須加引號(info.name) 
info['age'] = 20            // 修改
info['gender'] = 'male'     // 新增
delete info['age']          // 刪除

查看數據類型

typeof 變數名;
typeof n;   

註釋

單行//

多行 /**/

流程式控制制

if判斷

if (a == 1){       //判斷條件寫在小括弧裡面,大括弧裡面寫條件判斷成功後的代碼內容
    console.log('1111');      (類似print)
}
else{
   console.log('222');
}

多條件判斷

if(a > 1){
    // console.log('1111');
    // var hhhh = document.getElementById('d1');
    // hhhh.innerText = '彭於晏';
}else if(a<1){

    console.log('2222');
}else {
    console.log('3333');
}

運算符

比較運算

    > < == !=  >=  <=   ===  !==

var a = 2;
var b = '2';
a == b;  true  弱等於
a === b;  false  強等於
a != b;  false
a !== b;   true

算術運算

+  -  * / %   ++  --  
++ 自增 1  
-- 自減 1

var a = 2;
a++  先執行邏輯  +1
++a  先+1 再執行邏輯
簡單示例:
    if (++a === 4){                 //(a++ === 3)
        console.log('xxx');}
    else{
        console.log('ooo');};

switch判斷

用於判斷等於某些值(只能放數字)

var num = 200;
switch(num++){
    case 10:
        console.log('未成年');
        break;
    case 18:
        console.log('成年');
        break;
    case 35:
        console.log('老年');
        break;
    case 100:
        console.log('....');
        break;
    default:
        console.log('太大了');};

異常捕獲

try{
    console.log(xx);
}
catch(e){
    console.log(e);
}
finally{
    console.log('sssss');
}

迴圈

for迴圈

var names = ['老男孩', '肖峰', '吳超']

for(var i=0;i<names.lenght;i++){    js里for變例的i為索引
    console.log(i, names[i])
}



迴圈自定義對象--python字典
    for (var i in d){
        console.log(i,d[i]);     #不要用d.i來取值,沒有 i 屬性
    }

函數

普通函數

function f1(a,b){
    return a+b;
}
//   執行: f1(1,2) -- 3

function f1(a,b){
    return a,b;
};

f1(1,2);    //不能返回多個值:  2

匿名函數

一般用於當做參數使用
function (arg){
    return arg + 1;
}
——————————————————————————————

var a = function (a,b){
    console.log('xxx');
}

var d = {'xx':'oo','f':function (a,b){
    console.log('xxx');
}};
執行:d.f(1,2);    -------'xxx'

自執行函數

一般用於做數據隔離使用,因為JS中是以函數為作用域,所以當js代碼比較多時,通過自執行函數做數據隔離

(function () {
        alert('自執行函數!')
    })()

JSON

JSON.stringify 序列化

var info = {name:'alex',age:19,girls:['鋼彈','鐵錘']}
var infoStr = JSON.stringify(info)
console.log(infoStr) # '{"name":"alex","age":19,"girls":["鋼彈","鐵錘"]}'

JSON.parse 反序列化

//反序列化時鍵不能是數字且必須有雙引號
var infoStr = '{"name":"alex","age":19,"girls":["鋼彈","鐵錘"]}' 
var info = JSON.parse(infoStr)
console.log(info)

應用場景:
網路中數據傳輸本質上是基於字元串進行,如果想要把一個js的對象通過網路發送到某個網站,
就需要對對象進行序列化然後發送。(ajax會經常使用)
各語言之間數據類型不一定互通,需要一個中間人(json)  python->json->...->json->java

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 由於程式bug,導致之前很多數據入庫後信息不全,好在有基礎信息表,可以通過基礎信息表更新缺失欄位信息 1、通過 inner join語法實現多關聯更新 update a set a.name = b.name from product_detail a inner join product_base ...
  • 在公司隨便找3台測試機搭個MHA,下麵這個問題折騰了三天,之前沒遇到過,查了OS版本發現一致,可能是不同人弄的OS吧,知道是cpan的問題就是搞不定,鬱悶。。。[root@test247 ~]# masterha_check_repl --conf=/etc/masterha/app1.cnfWed ...
  • 一、分散式資料庫存儲 在前面的章節;GreenPlum資料庫是分散式架構資料庫;表的數據分佈在segment節點。那麼表的數據根據什麼策略來分佈的? GreenPlum資料庫性能依賴於跨數據節點均勻分佈 二、分佈策略 在GreenPlum資料庫在創建表時可以指定分佈策略:哈希分佈(DISTRIBUT ...
  • 假如有這樣一張表: 腳本如下: DROP TABLE IF EXISTS `jl_site_operation`;CREATE TABLE `jl_site_operation` ( `id` int(11) NOT NULL AUTO_INCREMENT, `site_id` int(11) DE ...
  • 文中使用mysql5.7 版本實現多實例,埠為3306和3307。 1、多實例本質在一臺機器上開啟多個不同的mysql服務埠(3306,3307),運行多個mysql服務進程,這些服務進程通過不同的socket監聽不同的服務埠來提供各自的服務; 多個實例共用一套mysql安裝程式,配置文件可以 ...
  • 轉載請標明出處:https://www.cnblogs.com/tangZH/p/11985745.html 有些手機中,給TextView設置lineSpacingExtra後會出現最後一行的文字也出現lineSpacingExtra,不是某些版本才會,這跟機型有關。 可以用下麵這種方法解決: ...
  • 作為JavaScript開發人員,NPM是我們一直使用的東西,並且我們的腳本在終端上連續運行。 如果我們可以節省一些時間呢? 1、直接從npm打開文檔 如果我們可以直接使用npm跳轉到軟體包的文檔怎麼辦? 2、打開bug頁面 為了以防萬一,我們想在程式包上提交一個錯誤。 如果有這個包的作者的鏈接,將 ...
  • 在web開發時,可能經常會用到sessionstorage存儲數據,存儲單個字元串數據變數時並不困難 var str = 'This is a string'; sessionstorage.setItem('param',str); 獲取sessionstorage var item = sess ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...