JS基礎-內置對象【字元串+Date+Math】

来源:https://www.cnblogs.com/chenyingying0/archive/2019/12/31/12123134.html
-Advertisement-
Play Games

JS內置對象【字元串】 // charAt() 返回字元 // charCodeAt() 返回字元的unicode編碼 var str="hello world"; console.log(str.charCodeAt(4)); // indexOf() 返回出現的位置 // 沒找到則返回-1 va ...


JS內置對象【字元串】

       // charAt() 返回字元
       // charCodeAt() 返回字元的unicode編碼
       var str="hello world";
       console.log(str.charCodeAt(4));
       // indexOf() 返回出現的位置
       // 沒找到則返回-1
       var email="[email protected]";
       console.log(email.indexOf("o"));
       console.log(email.lastIndexOf("."));
       var str="hello world";

案例:對用戶輸入內容的輸入框進行排查,看有沒有敏感字“草”字

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>搜索內容是否有敏感字"草"</title>
</head>
<body>
<script>
  //補充代碼
  var str=prompt('請輸入要搜索的內容!');
  var start=0;
  var first='';
  var key=0;
  first=str.indexOf('草');

  while(str.indexOf('草',start)!=-1){
      key=str.indexOf('草',start);
      document.write('敏感字在'+key+'位置被髮現<br>');
      start=key+1;
  }

  document.write('敏感字首次出現的位置是:'+first);
</script>
</body>
</html>

 

 

 

       // slice(start,end)截取字元串
       var str="hello world";
       console.log(str.slice(7,10));
       console.log(str.slice(1));
       //負數=總長度+該負數
       console.log(str.slice(-3));
       console.log(str.slice(-7,-2)); 
       // substring(start,end)與slice(start,end)類似,參數為負數自動轉為0
       // 將小的數作為開始,大的數作為結束
       console.log(str.substring(-7,5)); //(0,5)
       console.log(str.substring(2,-5)); //(0,2)
       str.substring(6,9)
       // substr(start,len)
       // len為負數則返回空字元串
       console.log(str.substr(6,3));
       console.log(str.substr(-5,4));  // (6,4)
       console.log(str.substr(3,-4));

判斷出“JavaScript”這個字元出現的位置,以及它在這段話中總共出現了幾次

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <script>
       var str='JavaScript 是屬於網路的腳本語言!JavaScript 被數百萬計的網頁用來改進設計、驗證表單、檢測瀏覽器、創建cookies,以及更多的應用。JavaScript 是網際網路上最流行的腳本語言。JavaScript很容易使用!你一定會喜歡它的!';
       var count=0;
       var key=0;

       while(str.indexOf('J',key)!=-1){
           key=str.indexOf('J',key);  
           var target=str.substr(key,10);
           count++;
           if(target=='JavaScript'){
              document.write('JavaScript第'+count+'次出現是在'+key+'的位置<br>');
           }
           key++;
       }
        document.write('JavaScript在這段話中一共出現了'+count+'次');
    </script>
</body>
</html>

 

 

 

       // 獲取擴展名
       var url="http://baidu.com/index.txt";
       function getFileFormat(url){
          // 獲取.在url中出現的位置
          var pos=url.lastIndexOf(".");
          //return url.substr(pos);
          return url.substr(pos+1);
       }
       var formatName=getFileFormat(url);
       var picFormat=getFileFormat("1231434.jpg")
       console.log(formatName);
       console.log(picFormat);
              // split()分割字元串 replace()替換字元串
              var str='welcome-to-beijing';
              //使用split將str轉換為數組
              //如果中間是用空字元串('')拆分,那麼字元串中的每個字元之間都會被分割
              var arr=str.split("-");
              var date='2019/12/31';
              //["welcome","to","beijing"]
              var dateArr=date.split("/");
              console.log(dateArr);
              console.log(arr);
              //replace()替換
              var tel='010-62971268,400-100-9098,010-86789889';
              //newTel被替換之後的字元串
              var newTel=tel.replace(',',"  ");
              console.log(newTel);

將連字元轉駝峰法表示

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <script>
       function camelback(str){
              //通過-分隔符將str拆分成數組
              var arr=str.split("-"),newStr=arr[0];
              for(var i=1,len=arr.length;i<len;i++){
                     var word=arr[i];
                     //將每一個單詞的首字母轉換為大寫
                     newStr+=word.charAt(0).toUpperCase()+word.substr(1);
                     // console.log(newStr)
              }
              return newStr;
       }
       var camelFormat=camelback("border-left-color");
       console.log(camelFormat)
    </script>
</body>
</html>

JS內置對象【Math

 

生成一個n到m之間的隨機整數

var random=Math.random();
       console.log(random);
       // 生成一個n到m之間的隨機整數
       function getRandom(n,m){
          var choise=m-n+1;  // 隨機整數的個數
          return Math.floor(Math.random()*choise+n);
       }
       var random1=getRandom(2,6);
       var random2=getRandom(10,88);

JS內置對象【date

       // 創建一個日期時間對象
       var weeks=["日","一","二","三","四","五","六"],
           today=new Date(),
           year=today.getFullYear(),
           month=today.getMonth()+1,
           date=today.getDate(),
           week=today.getDay(),
           hours=today.getHours(),
           minutes=today.getMinutes(),
           seconds=today.getSeconds(),
           times=today.getTime(),
           time=year+'年'+month+'月'+date+'日'+hours+'時'+minutes+'分'+seconds+'秒 星期'+weeks[week];
       console.log("現在是:"+time);
       console.log(times);
        // 創建一個日期時間對象
        //setMonth()是用來設置月份,月份的數值是介於0~11之間,如果數字大於11,那麼方法會自動往後順延一年
        var today=new Date();
        today.setFullYear(2017);
        today.setMonth(15);
        console.log(today.getFullYear());
        //  50天之後是星期
        // 第一種做法
        today.setDate(today.getDate()+50);
        console.log(today.getDay());
        // 第二種做法
        var weeks=["日","一","二","三","四","五","六"];
        var year=today.getFullYear();
        var month=today.getMonth();
        var day=today.getDate();
        // 創建了一個目標日期對象,年,月,日,時,分,秒
        var temp=new Date(year+1,month,day);
        console.log("50天後的今天是:"+temp.getFullYear()+'-'+(temp.getMonth()+1)+'-'+temp.getDate()+'-'+'星期'+weeks[temp.getDay()]);

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

-Advertisement-
Play Games
更多相關文章
  • 如何把局部變數變成全局變數? 把局部變數給window就可以了 函數的自調用 自調用函數 一次性的函數--聲明的同時, 直接調用了 (function () { console.log("函數"); })(); 局部變數 頁面載入後.這個自調用函數的代碼就執行完了 (function (形參) { ...
  • JS DOM設置元素屬性 設置id為box的這個元素的文字顏色,屬性是減號連接的複合形式時 必需要轉換為駝峰形式 var box=document.getElementById("box"); box.style.color='#f00'; box.style.fontWeight="bold"; ...
  • 事件基礎 註意:本文不會深入探究Javascript的事件迴圈。 提到事件,相信每位Javascript開發者都不會陌生,由於Javascript是先有實現,後有規範,因此,對於大部分人來說,事件模塊可以說是比較模糊的,本文將從不同角度幫助你理清楚事件模塊。 事件的本質可以說是一個回調函數,當事件觸 ...
  • 為了存放代碼新建了一個GitHub賬號,存放了一些比較常用的代碼塊。 地址:https://github.com/liuzhou1 目前就放了這幾個項目。 1.PC端非常好用的圖片預覽插件 jquery-viewer 2.js 圖片滑動驗證,驗證碼驗證 3.前端工程師通過微信小程式的雲開發操作資料庫 ...
  • 之前有個需求,由於H5端不支持TCPSocket通信,於是中間搭了個安卓框架作為通信的介質,在開發中遇到一個問題,當後端傳一個比較大的數據上來時,一條完整的數據會沒有規矩的分成若幹個包,每條數據可能不存在完整的包頭包尾。所以我想了一個用緩存數據的方法來對數據進行拼包。 後端會對每一串數據添加包頭(十 ...
  • 為內置對象添加原型方法 我們能否為系統的對象的原型中添加方法, 相當於在改變源碼 我希望字元串中有一個倒序字元串的方法 //我希望字元串中有一個倒序字元串的方法 String.prototype.myReverse = function () { for (var i = this.length - ...
  • ©Copyright 蕃薯耀 2019年12月31日 http://fanshuyao.iteye.com/ 使用方法: ©Copyright 蕃薯耀 2019年12月31日 http://fanshuyao.iteye.com/ ...
  • Iframe 高度自適應, js控制Iframe 高度自適應, iframe自適應高度 ©Copyright 蕃薯耀 2019年12月31日 http://fanshuyao.iteye.com/ 方法一:js控制Iframe 高度自適應 這個方法之前一直都在用,沒有問題,但最新發現有些情況不行(具 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...