JavaScript

来源:http://www.cnblogs.com/2-NARUTO-2/archive/2017/12/02/7954892.html
-Advertisement-
Play Games

1、js的簡介 (1)js是什麼? js是可以嵌入到html中,是基於對象和事件驅動的腳本語言。 特點: 交互性 安全性:js不能訪問本地磁碟 跨平臺:瀏覽器中都具備js解析器 (2)js能做什麼 js能動態的修改(增刪)html和css的代碼 能動態的校驗數據 (3)js的歷史及組成 BOM(瀏覽 ...


1、js的簡介

   (1)js是什麼?

    js是可以嵌入到html中,是基於對象和事件驅動的腳本語言。

         特點:

      交互性

            安全性:js不能訪問本地磁碟

      跨平臺:瀏覽器中都具備js解析器

      (2)js能做什麼

    js能動態的修改(增刪)html和css的代碼

    能動態的校驗數據

      (3)js的歷史及組成

    BOM(瀏覽器對象模型)DOM(文檔對象模型)

      (4)js被引入的方式

    內嵌腳本

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
    <input type = "button" value = "button" onclick="alert('xxx')">
</body>
</html>

 

    內部腳本

 

<script type="text/javascript">
    alert("xxx");
</script>

 

    外部腳本

      首先創建一個js文件

            其次在html中引入

 

<script type="text/javascript" src = "demo1.js"></script>

 

        js的代碼放在哪?

        放在哪都行 但是在不影響html功能的前提下,越晚載入越好。

2、js的基本語法:

  (1)變數

       方法1:

       var x = 5;

       x = 'javascript';

          var y = "hello";

       var b = true;

      方法2:

       x = 5;

  (2)原始數據類型

       number:數字類型

       string:字元類型

       boolean:布爾

       null:空類型

       underfind:未定義 

    註意:number、boolean、string是偽對象

    類型轉換:

      number\boolean轉成string:

        toString();

      string\boolean轉成number

        parseInt()

        parseFloat()

        boolean不能轉

              string可以將數字字元串轉換成number

           強制轉換

        Boolean()  強制轉換成布爾

           數字強制轉成成布爾 非零就是true 零就是false

              字元串強轉成布爾 非""就是true

        Number() 強制轉換成數字

             布爾轉數字 true轉成1  false轉成0

           字元串轉數字 不能強制轉換

  (3)引用數據類型

    java:Object obj = new Object();

    js:var obj = new Object();

       var num = new Number();

  (4)運算符

    賦值運算符

      var x = 5;

    算數運算符

      + - * \ %

      + : 遇到字元串變成連接

            - : 先把字元串轉成數字然後進行運算

    邏輯運算符

      &&  || 

    比較運算符

      >  <  >= !=  ==

      === : 全等:類型和值都要相等

    三元運算符

      3 < 2?"大於":"小於"

    void運算符

<a href="javascript:void(0);">xxx</a>

    類型運算符

      typeof : 判斷數據的類型(返回數據的類型)

      instanceof : 判斷數據類型(判斷是否是某種類型)

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>

<script type="text/javascript">
    var obj = new Object();
    alert(typeof obj);
    alert(obj instanceof Object);
</script>

</head>
<body>
    
</body>
</html>

    返回:Object true

  (5)邏輯語句

    (1)if-else

    (2)switch

    (3)for

    (4)for in 

3、js的內置對象

    (1)Number

      創建方式:

        var myNum = new Number(value);

        var myNum = Number(value);

        屬性和方法:

        toString():轉成字元串

        valueOf():返回一個Number對象的基本數字值

    (2)Boolean

       創建方式:

        var bool = new Boolean(value);

        var bool = Boolean(value);

      屬性和方法:

        toString():轉成字元串

       valueOf():返回一個Boolean對象的基本值

    (3)String

       創建方式:

        var str = new String(s);

        var str = String(s);

      屬性和方法:

        length:字元串的長度

        charAt() : 返回索引字元

        indexOf() : 返回字元索引

        lastIndexOf() : 逆向返回字元的索引

        split() : 將字元串按照特殊字元切割成數組

        substr() : 從起始索引號讀取字元串中指定數目的字元

        substring();  提取字元串中兩個指定的索引號之間的字元

        toUpperCase() : 轉大寫

    (4)Array

           創建方式:

        

 

         屬性和方法:

        length : 數組的長度。

           join() : 把數組的所有元素放入一個字元串。元素通過指定的分隔符進行分隔。

              pop() : 刪除並返回最後一個元素。

        push() : 向數組的末尾添加一個或多個元素,並返回新的長度

        reverse() : 反轉數組

        sort():排序

    (5)Date

          創建方式:

          var myDate = new Date();

          var myDate = new Date(毫米值); //代表從1970-1-1到現在的一個毫秒值

        屬性和方法:

          getFullYear() : 年

          getMonth() : 月 0 -11

          getDate() : 日 1-31

          getDay() :  星期 0 - 6

          getTime() : 代表從1970-1-1到指定日期(字元串)的一個毫秒數

          toLocaleString() : 獲得本地時間格式的字元串

    (6)Math        

          屬性和方法:

         PI : 圓周率

         abs() : 絕對值

            ceil() : 對數進行上舍入

         floor() : 對數進行向下舍入

         round() : 四捨五入

            pow(x,y) : 返回x的y次冪        

    (7)RegExp

        創建方式:

          var reg = new RegExp(pattern);

          var reg = /^正則規則$/;

        規則的寫法:

        [0-9]

        [A-Z]

        [a-z]

        [A-z]

         \ d 代表數字

        \D 代表非數字

        \w 查找代表字母

          \W 查找非單詞字元

        \s  查找空白字元

        \S 查找非空白字元 

        n+ 出現至少一次         

        n* 出現0次獲多次

        n? 出現0次或1次

        {5} 出現5次

        {2-8} 2到8次

      方法:

        test(str):檢索字元串中指定的值。返回true或false

      需求:

        校驗郵箱:

        var email = "[email protected]";

        var reg = /^[A-z]+[A-z0-9_-]*\@[A-z0-9]+\.[A-z]+$/;

        reg.test(email);

 

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>

<script type="text/javascript">
    var email = "[email protected]";
    var reg = /^[A-z]+[A-z0-9_-]*\@[A-z0-9]+\.[A-z]+$/;
    alert(reg.test(email));
</script>

</head>
<body>
    
</body>
</html>

 

  返回:true

 

4、js的函數

 

5、js的事件

 

6、js的bom

 

7、js的dom

 


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

-Advertisement-
Play Games
更多相關文章
  • 定義: 將一個複雜對象的構建與它的表示分離,使得同樣的構建過程可以創建不同的表示。生成器模式利用一個導演者對象和具體建造者對象一個一個地建造出所有的零件,從而建造出完整的對象。 四個要素: Builder:生成器介面,定義創建一個Product對象所需要的各個部件的操作。 ConcreteBuild ...
  • 一、kindedit編輯器 就是上面這樣的編輯輸入文本的一個編輯器 這也是一個插件。那麼怎麼用呢? 1、下載:百度kindedit 2、引入: 3、看官方提供的文檔 在addarticle.html中 當你把編輯器插入好的時候,你看似都可以設置大小,字體變粗等。。但是當你上傳圖片的時候就會想下麵一樣 ...
  • [toc] 功能和特性 基於socket實現的c/s架構的的通信 伺服器和客戶心跳連接 gson實現的消息通信機制 註冊及登錄 支持私聊和群聊。 動態更新用戶列表以及用戶消息提示 支持emoji表情,以及emoji表情選擇器 伺服器端資料庫用戶記錄 ~~實現文件傳輸~~ ~~文件記錄~~ 功能展示 ...
  • 寫什麼?為什麼寫?寫給誰看?這個是寫博客的首要問題。 寫什麼? 在這個分類下的文章主要是講一些博主對於JDK9的源碼理解結合一些入門級的數據結構與演算法。引用和知識來源主要來源於 CLRS(演算法導論),Alogrithms( 演算法 普林斯頓大學教材 鏈接:https://algs4.cs.prince ...
  • 文章目錄 ★引子 ★求導 ★最初的想法 ★初步的想法 ★後來的想法 ★最後的想法 ★編程範式 ★結尾 首先聲明一點,本文主要介紹的是面向對象(OO)的思想,順便談下函數式編程,而不是教你如何準確地、科學地用java求出函數在一點的導數。 ★引子 首先,直接上一段python代碼,請大家先分析下上面代 ...
  • 熔斷與降級 為什麼在RPC環節中有熔斷以及降級的需求,詳細的原因這裡不多解釋,從網上搜索一張圖做示意。 熔斷 我理解熔段主要解決如下幾個問題: 當所依賴的對象不穩定時,能夠起到快速失敗的目的 快速失敗後,能夠根據一定的演算法動態試探所依賴對象是否恢復 比如產品詳細頁獲取產品的好評總數時,由於後端服務異 ...
  • 你可能會疑惑為什麼我們使用6位數來表示一種顏色而不是只用一位或二位,答案是使用6位數可提供給我們巨大數量的顏色變化。 會有多少種可能的顏色?16 個值(0~F)和 6 個位置意味著我們有 16 的 6 次方,或者說超過 1600 萬種可能的顏色。 Hex code 遵循 red-green-blue ...
  • 很多情況下,你會使用 CSS 庫,這些庫可能會意外覆蓋掉你自己的 CSS。所以當你需要確保某元素具有指定的 CSS 時,你可以使用 !important。 Hello World!是粉色的 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...