複習 - ajax

来源:https://www.cnblogs.com/heymar/archive/2022/04/23/16181459.html
-Advertisement-
Play Games

複習呢有一個很直觀的感受,就是以前學的東西,萌懂半懂的,這一來全部都清楚了,你以前以為你學的並不好但是複習一次把以前的案例一做,居然能夠自己獨立完成,知識點看著掌握的還不錯。 1. 兩天時間就把整個ajax複習完了,一天目前還暫時做不到哈哈,確實還是有很多案例都要思考一會,直接從案例下手吧,一個圖書 ...


複習呢有一個很直觀的感受,就是以前學的東西,萌懂半懂的,這一來全部都清楚了,你以前以為你學的並不好但是複習一次把以前的案例一做,居然能夠自己獨立完成,知識點看著掌握的還不錯。

1.

兩天時間就把整個ajax複習完了,一天目前還暫時做不到哈哈,確實還是有很多案例都要思考一會,直接從案例下手吧,一個圖書管理的案例,在這個案例裡面吧就是用三個介面來獲取圖書,增加圖書,刪除圖書,在js方面沒多大問題,在html方面,還讓我多熟悉了下vscode快速編程bootstrap,直接bs3,form-inline類名可以讓每個表單項為行內塊元素,table-hover可以增加表格的每一行懸停效果。

獲取圖書列表:封裝為一個函數,通過ajax發起get請求,然後把拿到的數據通過foreach迴圈出來。

增加圖書列表:也是發起一起請求,然後要重新獲取一下列表

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <link rel="stylesheet" href="./lib/bootstrap.css">
    <style>
        .panel-body {
            text-align: center;
        }
        .input-group {
            width: 30%;
            margin:  0 10px;
        }
        .panel {
            width: 90%;
            margin: 0 auto;
        }
        .table {
            width: 90%;
            margin: 15px auto 0;
        }
    </style>
</head>

<body>
    
    <div class="panel panel-primary">
          <div class="panel-heading">
                <h3 class="panel-title">添加新圖書</h3>
          </div>
          <!-- 1.添加了一個類名form-inline 可使裡面的表單元素變成行內塊元素 -->
          <div class="panel-body form-inline">
               <div class="input-group ">
                   <div class="input-group-addon">書名</div>
                   <input type="text" class="form-control bookname" id="exampleInputAmount" placeholder="請輸入書名">
               </div>
               <div class="input-group">
                <div class="input-group-addon">作者</div>
                <input type="text" class="form-control author" id="exampleInputAmount" placeholder="請輸入作者">
            </div>
            <div class="input-group">
                <div class="input-group-addon">出版社</div>
                <input type="text" class="form-control publisher"  id="exampleInputAmount" placeholder="請輸入出版社">
            </div>
               <button type="button" class="btn btn-primary">添加</button>
          </div>
    </div>
    
    <!-- 2.table-borderred可以為每一個表單元素增加邊框 table-hover 添加滑鼠滑過表單的懸停狀態 -->
    
    <table class="table table-bordered table-hover">
        <thead>
            <tr>
                <th>id</th>
                <th>書名</th>
                <th>作者</th>
                <th>出版社</th>
                <th>操作</th>
            </tr>
        </thead>
        <tbody>
            
        </tbody>
    </table>
    
    

    <script src="./lib/jquery.js"></script>
    <script>
        /* $.get('http://www.liulongbin.top:3006/api/getbooks', res => {
            // console.log(res);
            if (res.status !== 200) return console.log(獲取數據失敗);
            let htmlStr = ''
            let str = ''
            res.data.forEach(item => {
                htmlStr = `<tr>
                <td>${item.id}</td>
                <td>${item.bookname}</td>
                <td>${item.author}</td>
                <td>${item.publisher}</td>
                <td><a href="javascript:;">刪除</a></td>
            </tr>`
            str += htmlStr
        })
        document.querySelector('tbody').innerHTML =  str
        }) */
        // 3.上面我自己的做的方法固然可以但是這裡既然是用的jq那就用jq的方法來實現
        function getBook() {
            $.ajax({
            method : 'get',
            url : 'http://www.liulongbin.top:3006/api/getbooks',
            success : res => {
                if (res.status !== 200) return alert('獲取數據失敗')
                // jq的迴圈方法
                // 註意這裡的i不能省略
                let arr = []
                $.each(res.data, (i, item) => {
                    arr.push(`<tr>
                <td>${item.id}</td>
                <td>${item.bookname}</td>
                <td>${item.author}</td>
                <td>${item.publisher}</td>
                <td><a href="javascript:;" data-id="${item.id}" class="del">刪除</a></td>
            </tr>`)
                })
                $('tbody').empty().append(arr.join(''))
        }})
        }
        getBook()
        // 刪除圖書模塊
        function delBook() {
            // 4.刪除圖書也要用到一個介面
           // 4.1註意這裡的jq的事件委托,在後代選擇器這裡,不管是寫id還是class還是標簽都不再需要$符號直接引號寫上來即可
           $('tbody').on('click', '.del' , function() {
                    // 這裡點誰就會觸發誰,用到了事件委托,說明現在每個a標簽上也有點擊事件了他們就是事件的調用者
                    // attr這個方法可以設置可以獲取屬性的值,刪除用removeAttr
                     let id = $(this).attr('data-id')
                     console.log(id);
                     $.get('http://www.liulongbin.top:3006/api/delbook', {id : id}, res => {
                         if (res.status !== 200) return alert('刪除失敗')
                         // 刪除成功刷新一下表格
                         getBook()
                     })
                })
        }
        delBook()
        // 添加圖書模塊
        function addBook() {
            $('.btn').on('click', function() {
                $.post('http://www.liulongbin.top:3006/api/addbook',{
                    bookname : $('.bookname').val(),
                    author : $('.author').val(),
                    publisher : $('.publisher').val()
                }, res => {
                    console.log(res);
                    if (res.status !== 201) return alert(res.msg)
                    getBook()
                    return alert(res.msg)
                })
            })
        }
        addBook()
    </script>
</body>
</html>

2.

第二個是一個聊天機器人的案例,以前也說過這些案例,只是這次來做感想又深入了一步,這個案例分為了三步,先是把自己發的消息能夠渲染到聊天界面,然後添加一個resetui重置右側滾動條的函數,可以讓聊天界面跟著我們的剛發的消息走,然後把獲取機器人回覆消息封裝為一個函數,具體裡面是通過我們發的消息為一個參數然後去獲取請求,會給你傳回來一個參數,同時可以把這個參數以機器人回覆的姿態渲染到聊天界面,最後就是語音播放功能,把機器人的消息作為一個參數封裝一個函數,html增加一個audio標簽,src就為我們這次請求的src,要加上網頁的一個根路徑哦

 <!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <link rel="stylesheet" href="css/reset.css" />
    <link rel="stylesheet" href="css/main.css" />
    <script type="text/javascript" src="js/jquery-1.12.4.min.js"></script>
    <script type="text/javascript" src="js/jquery-ui.min.js"></script>
    <script type="text/javascript" src="js/jquery.mousewheel.js"></script>
    <title>聊天機器人</title>
  </head>

  <body>
    <div class="wrap">
      <!-- 頭部 Header 區域 -->
      <div class="header">
        <h3>小思同學</h3>
        <img src="img/person01.png" alt="icon" />
      </div>
      <!-- 中間 聊天內容區域 -->
      <div class="main">
        <ul class="talk_list" style="top: 0px;">
       
          
        </ul>
        <div class="drag_bar" style="display: none;">
          <div
            class="drager ui-draggable ui-draggable-handle"
            style="display: none; height: 412.628px;"
          ></div>
        </div>
      </div>
      <!-- 底部 消息編輯區域 -->
      <div class="footer">
        <img src="img/person02.png" alt="icon" />
        <input type="text" placeholder="說的什麼吧..." class="input_txt" />
        <input type="button" value="發 送" class="input_sub" />
      </div>
    </div>
    <audio src="" autoplay></audio>
    <!-- <script type="text/javascript" src="./js/scroll.js"></script> -->
    <!-- <script>
      $(function(){
        // 初始化右側滾動條
        // 這個方法定義在scroll.js中
        resetui()
      })
      
    </script> -->
    <!-- 1.下麵兩個jq的js都是為了配合最後一個可以用resetui函數來初始化右側滾動條讓滾動條跟著屏幕內容走 -->
    <script src="./js/jquery-1.12.4.min.js"></script>
    <script src="./js/jquery-ui.min.js"></script>
    <script src="./js/jquery.mousewheel.js"></script>
    <script src="./js/scroll.js"></script>
    <script>
      // 先完成點擊發送添加消息功能
      let content = ''
      $('.input_sub').on('click', function() {
        content = $('.input_txt').val()
        if (content.trim() == '') return
        $('.talk_list').append(`<li class="right_word">
            <img src="img/person02.png" /> <span>${content}</span>
          </li>`
      )
      $('.input_txt').val('')
      resetui()
      getBoot(content)
    })
    // 機器人回覆
    // 2.註意這裡機器人的回覆是怎麼做到的 是再點擊後調用的這個函數
    function getBoot(text) {
      $.get('http://www.liulongbin.top:3006/api/robot',{spoken : text},res => {
      console.log(res);
      if (res.message == 'success') {
        $('.talk_list').append(`<li class="left_word">
            <img src="img/person01.png" /> <span>${res.data.info.text}</span>
          </li>`
      )
      }
      resetui(

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

-Advertisement-
Play Games
更多相關文章
  • 分享嘉賓:高大月@美團點評,Apache Kylin PMC成員,Druid Commiter 編輯整理:Druid中國用戶組 6th MeetUp 出品平臺:DataFunTalk -- 導讀: 長久以來,對SQL和許可權的支持一直是Druid的軟肋。雖然社區早在0.9和0.12版本就分別添加了對S ...
  • Quantexa 服務特色是場景決策智能CDI(contextual decision intelligence) 主要落地場景是金融以及涉及交易的各類機構的反洗錢反金融詐騙, 客戶畫像, 風控 解決的問題是監管合規, 降低誤判率, 提高準確率, 降成本, 提高行業競爭力 面向的主要客戶是銀行, 保... ...
  • 一、Spark SQL概述 Spark SQL是Spark用來處理結構化數據的一個模塊,它提供了兩個編程抽象叫做DataFrame和DataSet並且作為分散式SQL查詢引擎的作用,其實也是對RDD的再封裝。大數據Hadoop之——計算引擎Spark,官方文檔:https://spark.apach ...
  • Q644F/Q645F氣動三通球閥是一種三通道的迴轉型球閥 用於介質分流、合流及流向切換,任何一個管道都可以作為入口或出口。氣動三通球閥分有氣動三通L型球閥和氣動三通T型球閥兩種,可以滿足不同的生產工藝要求。氣動三通L型球閥是對三條管道中的兩條管道進行切斷,氣動三通T型球閥實現把三條連通管道進行合流... ...
  • Q941F電動調節球閥適用於經常操作、兩位切斷、調節的場合。球閥與執行機構的連接採用直連方式,電動執行機構內置伺服系統,無須另配伺服放大器,輸入 4~20mA 信號及 220V AC 電源即可控制運轉。具有連線簡單,結構緊湊、尺寸小、重量輕、阻力小、動作穩定可靠等優點。執行機構可根據用戶要求配置不同... ...
  • 高平臺球閥主要用於截斷或接通介質,也可用於流體的調節與控制。與其它閥類相比,球閥具優點1、流體阻力小,球閥是所有閥類中流體阻力最小的一種,即使是縮徑球閥,其流體阻力也相當小。 ...
  • 前言 【筆記內容】 關於JSchallenger中Set對象題目的復盤 本人的提交、以及做題時的思路 分析作者答案 涉及的知識快速瞭解,註意:並不深入分析具體知識,只是圍繞題目展開 【筆記目的】 幫助本人進一步瞭解Javascript的Set對象以及涉及的方法 對自己做題後的復盤,進一步瞭解自己的不 ...
  • 大家好,我是半夏👴,一個剛剛開始寫文的沙雕程式員.如果喜歡我的文章,可以關註➕ 點贊 👍 加我微信:frontendpicker,一起學習交流前端,成為更優秀的工程師~關註公眾號:搞前端的半夏,瞭解更多前端知識! 點我探索新世界! 原文鏈接 ==>http://sylblog.xin/archi ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...