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 Framework 4.8 開發的深度學習模型部署測試平臺,提供了YOLO框架的主流系列模型,包括YOLOv8~v9,以及其系列下的Det、Seg、Pose、Obb、Cls等應用場景,同時支持圖像與視頻檢測。模型部署引擎使用的是OpenVINO™、TensorRT、ONNX runti... ...
  • 十年沉澱,重啟開發之路 十年前,我沉浸在開發的海洋中,每日與代碼為伍,與演算法共舞。那時的我,滿懷激情,對技術的追求近乎狂熱。然而,隨著歲月的流逝,生活的忙碌逐漸占據了我的大部分時間,讓我無暇顧及技術的沉澱與積累。 十年間,我經歷了職業生涯的起伏和變遷。從初出茅廬的菜鳥到逐漸嶄露頭角的開發者,我見證了 ...
  • C# 是一種簡單、現代、面向對象和類型安全的編程語言。.NET 是由 Microsoft 創建的開發平臺,平臺包含了語言規範、工具、運行,支持開發各種應用,如Web、移動、桌面等。.NET框架有多個實現,如.NET Framework、.NET Core(及後續的.NET 5+版本),以及社區版本M... ...
  • 前言 本文介紹瞭如何使用三菱提供的MX Component插件實現對三菱PLC軟元件數據的讀寫,記錄了使用電腦模擬,模擬PLC,直至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1. PLC開發編程環境GX Works2,GX Works2下載鏈接 https:// ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • 1、jQuery介紹 jQuery是什麼 jQuery是一個快速、簡潔的JavaScript框架,是繼Prototype之後又一個優秀的JavaScript代碼庫(或JavaScript框架)。jQuery設計的宗旨是“write Less,Do More”,即倡導寫更少的代碼,做更多的事情。它封裝 ...
  • 前言 之前的文章把js引擎(aardio封裝庫) 微軟開源的js引擎(ChakraCore))寫好了,這篇文章整點js代碼來測一下bug。測試網站:https://fanyi.youdao.com/index.html#/ 逆向思路 逆向思路可以看有道翻譯js逆向(MD5加密,AES加密)附完整源碼 ...
  • 引言 現代的操作系統(Windows,Linux,Mac OS)等都可以同時打開多個軟體(任務),這些軟體在我們的感知上是同時運行的,例如我們可以一邊瀏覽網頁,一邊聽音樂。而CPU執行代碼同一時間只能執行一條,但即使我們的電腦是單核CPU也可以同時運行多個任務,如下圖所示,這是因為我們的 CPU 的 ...
  • 掌握使用Python進行文本英文統計的基本方法,並瞭解如何進一步優化和擴展這些方法,以應對更複雜的文本分析任務。 ...
  • 背景 Redis多數據源常見的場景: 分區數據處理:當數據量增長時,單個Redis實例可能無法處理所有的數據。通過使用多個Redis數據源,可以將數據分區存儲在不同的實例中,使得數據處理更加高效。 多租戶應用程式:對於多租戶應用程式,每個租戶可以擁有自己的Redis數據源,以確保數據隔離和安全性。 ...