AJAX---個人信息案例

来源:https://www.cnblogs.com/Ayako/archive/2022/11/17/16900651.html
-Advertisement-
Play Games

案例分析: 如圖所示,頁面載入時有數據回填,同時實現select表單同步和圖片上傳,保存後上傳至伺服器等功能 HTML模板: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta http-equiv="X-UA ...


案例分析:

如圖所示,頁面載入時有數據回填,同時實現select表單同步和圖片上傳,保存後上傳至伺服器等功能

HTML模板:


<!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>08.案例_個人信息修改</title>
  <link rel="stylesheet" href="https://unpkg.com/[email protected]/dist/css/bootstrap.min.css" />
  <style>
    .form-select {
      width: 103px;
      display: inline-block;
    }

    .col-form-label {
      text-align: right;
    }

    .figure-img {
      width: 100px;
      height: 100px;
      cursor: pointer;
    }

    #upload {
      display: none;
    }
  </style>
</head>

<body>
  <div class="container">
    <h1 class="p-5">個人設置</h1>
    <form class="col-6">
      <div class="row mb-3">
        <label class="col-form-label col-3">昵稱:</label>
        <div class="col-9">
          <input class="form-control col-9" type="text" name="nickname" />
        </div>
      </div>
      <div class="row mb-3">
        <label class="col-form-label col-3">籍貫:</label>
        <div class="col-9">
          <select class="form-select col-4" name="province">
            <option value="">--省--</option>
          </select>
          <select class="form-select col-4" name="city">
            <option value="">--市--</option>
          </select>
          <select class="form-select col-4" name="area">
            <option value="">--區--</option>
          </select>
        </div>
      </div>
      <div class="row mb-3">
        <label class="col-form-label col-3">頭像:</label>
        <div class="col-9">
          <input class="form-control col-9" type="hidden" name="avatar" />
          <figure class="figure">
            <input type="file" id="upload" />
            <img src="https://yanxuan-item.nosdn.127.net/12a882699bd531a1bd428bffe1989525.jpg"
              class="figure-img img-fluid rounded" alt="..." />
            <figcaption class="figure-caption">修改頭像</figcaption>
          </figure>
        </div>
      </div>
      <div class="row mb-3">
        <label class="col-3"></label>
        <div class="col-9">
          <button class="btn btn-primary">保存</button>
        </div>
      </div>
    </form>
  </div>

  <script src="https://unpkg.com/[email protected]/dist/js/bootstrap.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/axios.min.js"></script>
  <script src="./lib/form-serialize.js"></script>
 
</body>

</html>

一.頁面回填

通過獲取內置個人信息進行頁面回填

<script>
    // 首碼基地址
    axios.defaults.baseURL = 'http://ajax-api.itheima.net/'
    // 獲取標簽方法$
    function $(id) {
        return document.querySelector('#' + id)
    }
    // 數據回填方法
    async function getInfo() {
        const res = await axios.get('api/settings')
        const { nickname, province, city, area, avatar } = res.data.data
        // 昵稱
        $('nickname').value = nickname
        // 頭像地址
        $('avatar').src = avatar
        // 給頭像框input進行賦值,方便後期拿取數據
        $('avatarInp').value = avatar
        // 省數據
        const provinceAll = await axios.get('api/province')
        $('province').innerHTML += provinceAll.data.data.map(item => `<option value="${item}">${item}</option>`).join('')
        $('province').value = province
        // 市數據
        const cityAll = await axios.get('api/city?pname=' + province)
        $('city').innerHTML += cityAll.data.data.map(item => `<option value="${item}">${item}</option>`).join('')
        $('city').value = city
        // 區數據
        const areaAll = await axios.get(`api/area?pname=${province}&cname=${city}`)
        $('area').innerHTML += areaAll.data.data.map(item => `<option value="${item}">${item}</option>`).join('')
        $('area').value = area

    }
    // 調用回填方法
    getInfo()
</script>

二.省市區下拉框的聯動

<script>
    // 省數據下拉框
    $('province').addEventListener('change', async () => {
        // 獲取省下市數據
        const cityAll = await axios.get('api/city?pname=' + $('province').value)
        // 渲染市數據
        $('city').innerHTML = cityAll.data.data.map(item => `<option value="${item}">${item}</option>`).join('')
        // 獲取市下區數據
        const areaAll = await axios.get(`api/area?pname=${$('province').value}&cname=${$('city').value}`)
        // 渲染區數據
        $('area').innerHTML = areaAll.data.data.map(item => `<option value="${item}">${item}</option>`).join('')
    })

    $('city').addEventListener('change', async () => {
        const areaAll = await axios.get(`api/area?pname=${$('province').value}&cname=${$('city').value}`)
        $('area').innerHTML = areaAll.data.data.map(item => `<option value="${item}">${item}</option>`).join('')
    })
</script>

三.頭像圖片上傳功能

<script>
    // 圖片上傳功能
    $('upload').addEventListener('change', (e) => {
        // 非空判斷
        if (e.target.files.length === 0) {
            return
        }
        // 創建FormData接收
        const fd = new FormData()
        // 將圖片數據添加到fd中
        fd.append('avatar', e.target.files[0])
        // 圖片上傳介面
        axios.post('api/file', fd).then(res => {
            console.log(res);
            $('avatar').src = res.data.data.url
            //  給頭像框input進行賦值,方便拿取數據
            $('avatarInp').value = res.data.data.url
        })
    })
    // 圖片點擊事件
    $('avatar').addEventListener('click', () => {
        // 優化圖片上傳功能
        $('upload').click()
    })      
</script>

四.將數據上傳至伺服器保存

<script>
    // 上傳點擊事件
    $('uploadAll').addEventListener('click', async (e) => {
        // 取消預設刷新操作
        e.preventDefault()
        // 用serialize獲取表單中所有內容(前面給頭像框input賦值的應用)
        const userFormall = serialize($('userForm'), { hash: true })
        try {
            // 執行成功,上傳數據並彈出ok彈框
            await axios.put('api/settings', userFormall)
            alert('ok')
        } catch (error) {
            alert('error')
        }
    })
</script>

五.個人經驗

①省市區下拉框聯動時,操作省數據聯動市數據時,仍需對區數據進行聯動

②給圖片input框的value賦值,方便最後上傳伺服器時用serialize獲取數據

③附完整源碼

<!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>08.案例_個人信息修改</title>
    <link rel="stylesheet" href="https://unpkg.com/[email protected]/dist/css/bootstrap.min.css" />
    <style>
        .form-select {
            width: 103px;
            display: inline-block;
        }

        .col-form-label {
            text-align: right;
        }

        .figure-img {
            width: 100px;
            height: 100px;
            cursor: pointer;
        }

        #upload {
            display: none;
        }
    </style>
</head>

<body>
    <div class="container">
        <h1 class="p-5">個人設置</h1>
        <form class="col-6" id="userForm">
            <div class="row mb-3">
                <label class="col-form-label col-3">昵稱:</label>
                <div class="col-9">
                    <input class="form-control col-9" type="text" name="nickname" id="nickname" />
                </div>
            </div>
            <div class="row mb-3">
                <label class="col-form-label col-3">籍貫:</label>
                <div class="col-9">
                    <select class="form-select col-4" name="province" id="province">
                        <option value="">--省--</option>
                    </select>
                    <select class="form-select col-4" name="city" id="city">
                        <option value="">--市--</option>
                    </select>
                    <select class="form-select col-4" name="area" id="area">
                        <option value="">--區--</option>
                    </select>
                </div>
            </div>
            <div class="row mb-3">
                <label class="col-form-label col-3">頭像:</label>
                <div class="col-9">
                    <input class="form-control col-9" type="hidden" name="avatar" id="avatarInp" />
                    <figure class="figure">
                        <input type="file" id="upload" />
                        <img src="https://yanxuan-item.nosdn.127.net/12a882699bd531a1bd428bffe1989525.jpg"
                            class="figure-img img-fluid rounded" alt="..." id="avatar" />
                        <figcaption class="figure-caption" id="load">修改頭像</figcaption>
                    </figure>
                </div>
            </div>
            <div class="row mb-3">
                <label class="col-3"></label>
                <div class="col-9">
                    <button class="btn btn-primary"   id="uploadAll">保存</button>
                </div>
            </div>
        </form>
    </div>

    <script src="https://unpkg.com/[email protected]/dist/js/bootstrap.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/axios.min.js"></script>
    <script src="./lib/form-serialize.js"></script>
    <script>
        // 首碼基地址
        axios.defaults.baseURL = 'http://ajax-api.itheima.net/'
        // 獲取標簽方法$
        function $(id) {
            return document.querySelector('#' + id)
        }
        // 數據回填方法
        async function getInfo() {
            const res = await axios.get('api/settings')
            const { nickname, province, city, area, avatar } = res.data.data
            // 昵稱
            $('nickname').value = nickname
            // 頭像地址
            $('avatar').src = avatar
            // 給頭像框input進行賦值,方便後期拿取數據
            $('avatarInp').value = avatar
            // 省數據
            const provinceAll = await axios.get('api/province')
            $('province').innerHTML += provinceAll.data.data.map(item => `<option value="${item}">${item}</option>`).join('')
            $('province').value = province
            // 市數據
            const cityAll = await axios.get('api/city?pname=' + province)
            $('city').innerHTML += cityAll.data.data.map(item => `<option value="${item}">${item}</option>`).join('')
            $('city').value = city
            // 區數據
            const areaAll = await axios.get(`api/area?pname=${province}&cname=${city}`)
            $('area').innerHTML += areaAll.data.data.map(item => `<option value="${item}">${item}</option>`).join('')
            $('area').value = area

        }
        // 調用回填方法
        getInfo()

        // 省數據下拉框
        $('province').addEventListener('change', async () => {
            // 獲取省下市數據
            const cityAll = await axios.get('api/city?pname=' + $('province').value)
            // 渲染市數據
            $('city').innerHTML = cityAll.data.data.map(item => `<option value="${item}">${item}</option>`).join('')
            // 獲取市下區數據
            const areaAll = await axios.get(`api/area?pname=${$('province').value}&cname=${$('city').value}`)
            // 渲染區數據
            $('area').innerHTML = areaAll.data.data.map(item => `<option value="${item}">${item}</option>`).join('')
        })

        $('city').addEventListener('change', async () => {
            const areaAll = await axios.get(`api/area?pname=${$('province').value}&cname=${$('city').value}`)
            $('area').innerHTML = areaAll.data.data.map(item => `<option value="${item}">${item}</option>`).join('')
        })

        // 圖片上傳功能
        $('upload').addEventListener('change',(e)=>{
            // 非空判斷
            if(e.target.files.length===0){
                return
            }
            // 創建FormData接收
            const fd = new FormData()
            // 將圖片數據添加到fd中
            fd.append('avatar', e.target.files[0])
            // 圖片上傳介面
            axios.post('api/file',fd).then(res=>{
                console.log(res);
                $('avatar').src = res.data.data.url
                //  給頭像框input進行賦值,方便拿取數據
                $('avatarInp').value = res.data.data.url
            })
        })
        // 圖片點擊事件
        $('avatar').addEventListener('click',()=>{
            // 優化圖片上傳功能
            $('upload').click()
        })
      
        // 上傳點擊事件
        $('uploadAll').addEventListener('click', async (e)=>{
            // 取消預設刷新操作
            e.preventDefault()
            // 用serialize獲取表單中所有內容(前面給頭像框input賦值的應用)
            const userFormall = serialize($('userForm'),{hash:true})
            try {
                // 執行成功,上傳數據並彈出ok彈框
                await axios.put('api/settings',userFormall)
                alert('ok')
            } catch (error) {
                alert('error')
            }
        })
    </script>
</body>

</html>

本文來自博客園,作者:三井綾子,轉載請註明原文鏈接:https://www.cnblogs.com/Ayako/p/16900651.html


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

-Advertisement-
Play Games
更多相關文章
  • 一 演算法複雜度 演算法複雜度分為時間複雜度和空間複雜度。時間複雜度是指執行演算法所需要的計算工作量;而空間複雜度是指執行這個演算法所需要的記憶體空間。 演算法的複雜性體運行該演算法時的電腦所需資源的多少,電腦資源最重要的是時間和空間(即寄存器)資源,因此複雜度分為時間和空間複雜度。 二 時間複雜度 2.1 ...
  • 摘要 在Prism中彈出一個對話框,預設是一個Windows預設樣式的視窗,會與自己所開發的項目完全不搭配,例如下麵這樣子 如果為了迎合軟體主體風格,可以做出類似這樣效果 其實原理也很簡單,Prism也考慮到了這一點,所以特意設計一個供用戶自定義的介面 編寫組件樣式 1、新建一個Window視圖 註 ...
  • 大家都用過Linux中的應用程式安裝工具,如yum、apt、rpm等工具進行安裝自己想要的一些工具或則軟體之類的,當然Linux操作系統還是很強大的有很多類似的命令來安裝我們所需要的程式,但是windwos有沒有類似於windows這樣的應用安裝程式呢?想必大家看標題就能看的出來肯定是有的,那就是微 ...
  • //源文件 void ADCPhyConfig() { RCC->APB2ENR |=1 <<8; //使能 ADC1 時鐘 RCC->AHB1ENR |=1 <<0; //使能 PORTA 時鐘 //PA5 輸入模式、下拉、高速 GPIOA->MODER |= (3<<5*2); //輸入模式 G ...
  • 1.打開手機,開發者選項,開啟usb調試 , 無線調試,查看手機ip 2.cmd 測試是否能ping通手機 > ping 192.168.0.102正在 Ping 192.168.0.102 具有 32 位元組的數據:來自 192.168.0.102 的回覆: 位元組=32 時間=283ms TTL=6 ...
  • UTF-8編碼的漢字:少數是漢字每個占用3個位元組,多數占用4個位元組 # GET請求編碼 Chrome會先把URL中非ASCII字元按照某種編碼格式(谷歌瀏覽器是UTF-8)編碼成byte數組後,然後轉成16進位數組,然後在每個16進位數字前加上&分割 eg: 地址欄:http://localhost ...
  • 好家伙, 頂不住了,太多的bug, 本來是想把背景用canvas做成動態的,但是,出現了各種問題 為了不耽誤進度,我們先把一個簡單的登錄註冊界面做出來 來看看效果: (看上去還不錯) 本界面使用Vue2(新建項目的時候記得把less勾上,項目里有用到) 1.項目目錄: 2.MyLogin.vue組件 ...
  • 以谷歌內核的瀏覽器擴展,包括 edge chrome ,還有我們常用的國產瀏覽器都能使用 瀏覽器擴展是一種軟體,以增強Chrome內核瀏覽器的功能。瀏覽器擴展使用HTML、JavaScript、CSS和圖片等Web技術開發。 瀏覽器擴展與瀏覽器插件不同。瀏覽器擴展無需瞭解瀏覽器的源代碼,而瀏覽器插件 ...
一周排行
    -Advertisement-
    Play Games
  • JWT(JSON Web Token)是一種用於在網路應用之間傳遞信息的開放標準(RFC 7519)。它使用 JSON 對象在安全可靠的方式下傳遞信息,通常用於身份驗證和信息交換。 在Web API中,JWT通常用於對用戶進行身份驗證和授權。當用戶登錄成功後,伺服器會生成一個Token並返回給客戶端 ...
  • 老周在幾個世紀前曾寫過樹莓派相關的 iOT 水文,之所以沒寫 Nano Framework 相關的內容,是因為那時候這貨還不成熟,可玩性不高。不過,這貨現在已經相對完善,老周都把它用在項目上了——第一個是自製的智能插座,這個某寶上50多塊可以買到,搜“esp32 插座”就能找到。一種是 86 型盒子 ...
  • 引言 上一篇我們創建了一個Sample.Api項目和Sample.Repository,並且帶大家熟悉了一下Moq的概念,這一章我們來實戰一下在xUnit項目使用依賴註入。 Xunit.DependencyInjection Xunit.DependencyInjection 是一個用於 xUnit ...
  • 在 Avalonia 中,樣式是定義控制項外觀的一種方式,而控制項主題則是一組樣式和資源,用於定義應用程式的整體外觀和感覺。本文將深入探討這些概念,並提供示例代碼以幫助您更好地理解它們。 樣式是什麼? 樣式是一組屬性,用於定義控制項的外觀。它們可以包括背景色、邊框、字體樣式等。在 Avalonia 中,樣 ...
  • 在處理大型Excel工作簿時,有時候我們需要在工作表中凍結窗格,這樣可以在滾動查看數據的同時保持某些行或列固定不動。凍結窗格可以幫助我們更容易地導航和理解複雜的數據集。相反,當你不需要凍結窗格時,你可能需要解凍它們以獲得完整的視野。 下麵將介紹如何使用免費.NET庫通過C#實現凍結Excel視窗以鎖 ...
  • .NET 部署 IIS 的簡單步驟一: 下載 dotnet-hosting-x.y.z-win.exe ,下載地址:.NET Downloads (Linux, macOS, and Windows) (microsoft.com) .NET 部署 IIS 的簡單步驟二: 選擇對應的版本,點擊進入詳 ...
  • 拓展閱讀 資料庫設計工具-08-概覽 資料庫設計工具-08-powerdesigner 資料庫設計工具-09-mysql workbench 資料庫設計工具-10-dbdesign 資料庫設計工具-11-dbeaver 資料庫設計工具-12-pgmodeler 資料庫設計工具-13-erdplus ...
  • 初識STL STL,(Standard Template Library),即"標準模板庫",由惠普實驗室開發,STL中提供了非常多對信息學奧賽很有用的東西。 vector vetor是STL中的一個容器,可以看作一個不定長的數組,其基本形式為: vector<數據類型> 名字; 如: vector ...
  • 前言 最近自己做了個 Falsk 小項目,在部署上伺服器的時候,發現雖然不乏相關教程,但大多都是將自己項目代碼複製出來,不講核心邏輯,不太簡潔,於是將自己部署的經驗寫成內容分享出來。 uWSGI 簡介 uWSGI: 一種實現了多種協議(包括 uwsgi、http)並能提供伺服器搭建功能的 Pytho ...
  • 1 文本Embedding 將整個文本轉化為實數向量的技術。 Embedding優點是可將離散的詞語或句子轉化為連續的向量,就可用數學方法來處理詞語或句子,捕捉到文本的語義信息,文本和文本的關係信息。 ◉ 優質的Embedding通常會讓語義相似的文本在空間中彼此接近 ◉ 優質的Embedding相 ...