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
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...