溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

發(fā)布時(shí)間:2023-03-13 15:32:09 來(lái)源:億速云 閱讀:150 作者:iii 欄目:開(kāi)發(fā)技術(shù)

這篇文章主要介紹了Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。

這是個(gè)全新的Vue項(xiàng)目,引入了ElementUI

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

 將App.vue里的內(nèi)容干掉,剩如下

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

然后下面的三個(gè)文件也可以刪掉了

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

在views文件下新建Login.vue組件

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

 到router目錄下的index.js

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

 那么現(xiàn)在的流程大概是這樣子的

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

 啟動(dòng)

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

 寫(xiě)登陸頁(yè)面

<template>
  <div>
    <el-form :ref="form" :model="loginForm" class="loginContainer">
      <h4 class="loginTitle">系統(tǒng)登錄</h4>
      <!-- auto-complete="false"自動(dòng)補(bǔ)全 -->
      <el-form-item label="">   
        <el-input type="text" auto-complete="false" v-model="loginForm.username" placeholder="請(qǐng)輸入用戶(hù)名"></el-input>
      </el-form-item>
      <el-form-item label="">
        <el-input type="text" auto-complete="false" v-model="loginForm.password" placeholder="請(qǐng)輸入密碼"></el-input>
      </el-form-item>
      <el-form-item label="">
        <el-input type="text" auto-complete="false" v-model="loginForm.code" placeholder="點(diǎn)擊圖片更換驗(yàn)證碼" ></el-input>
        <img :src="captchaUrl"/>
       </el-form-item>
       <el-checkbox v-model="checked" class="loginRemeber">記住我</el-checkbox>
       <el-button type="primary" >登錄</el-button>
    </el-form>
  </div>
</template>
 
<script>
export default {
    name:"Login",
    data(){
        return{
            captchaUrl:'',//驗(yàn)證碼圖片鏈接
            loginForm:{
                username:'admin',
                password:'123456',
                code:'1234'
            },
            checked:true
        }
    }
 
}
</script>
 
<style>
    .loginContainer{
        border-radius: 15px;
        background-clip: padding-box;
        margin:180px auto;
        width:350px;
        padding: 15px 35px 15px 35px;
        background: #a8dad5;
        border:1px solid #eaeaea;
        box-shadow: 0 0 25px #cac6c6;
    }
    .loginTitle{
        margin: 0px auto 40px auto;
        text-align: center;
    }
    .loginRemeber{
        text-align: left;
        margin:0px 0px 15px 0px;
    }
</style>

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

給登錄按鈕添加點(diǎn)擊事件

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

添加方法

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

 添加表單校驗(yàn)  暫時(shí)先吧:ref="form"去掉

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

校驗(yàn)的username,password,code需要和上面的對(duì)應(yīng)上 需要加prop屬性

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

測(cè)試,校驗(yàn)規(guī)則是存在的,但是出現(xiàn)的問(wèn)題是點(diǎn)擊表單還是生效的

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

在點(diǎn)擊登錄時(shí)候添加表單校驗(yàn)

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

會(huì)自動(dòng)根據(jù)我們自己定義的校驗(yàn)規(guī)則來(lái)校驗(yàn),還是將用戶(hù)名長(zhǎng)度改成5位好了 

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

用ElementUI的showMessage

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

效果如下

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

接下來(lái)需要發(fā)送axios請(qǐng)求

安裝axios

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

安裝完成,可以在package.json文件看到

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

 組件里引入

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

 這里我隨便建個(gè)后端,先進(jìn)行演示,會(huì)出現(xiàn)跨域現(xiàn)象,這里跨域先不講

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

 看下返回的信息里有什么

Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求

<template>
  <div>
    <el-form :rules="rules" ref="form" :model="loginForm" class="loginContainer">
      <h4 class="loginTitle">系統(tǒng)登錄</h4>
      <!-- auto-complete="false"自動(dòng)補(bǔ)全 -->
      <el-form-item prop="username">   
        <el-input type="text" auto-complete="false" v-model="loginForm.username" placeholder="請(qǐng)輸入用戶(hù)名"></el-input>
      </el-form-item>
      <el-form-item prop="password">
        <el-input type="text" auto-complete="false" v-model="loginForm.password" placeholder="請(qǐng)輸入密碼"></el-input>
      </el-form-item>
      <el-form-item prop="code">
        <el-input type="text" auto-complete="false" v-model="loginForm.code" placeholder="點(diǎn)擊圖片更換驗(yàn)證碼" ></el-input>
        <img :src="captchaUrl"/>
       </el-form-item>
       <el-checkbox v-model="checked" class="loginRemeber">記住我</el-checkbox>
       <el-button type="primary"  @click="submitLogin">登錄</el-button>
    </el-form>
  </div>
</template>
 
 
<script>
import axios from 'axios'
export default {
    name:"Login",
    data(){
        return{
            captchaUrl:'',//驗(yàn)證碼圖片鏈接
            loginForm:{
                username:'admin',
                password:'123456',
                code:'1234'
            },
            checked:true,
            rules:{
                username:[
                    {required:true,message:'請(qǐng)輸入用戶(hù)名',trigger:'blur'},
                    {min:5,max:12,message:'用戶(hù)名長(zhǎng)度6到12位',trigger:'blur'}
                ],
                password:[
                    {required:true,message:'請(qǐng)輸入密碼',trigger:'blur'},
                    {min:6,max:12,message:'密碼長(zhǎng)度6到12位',trigger:'blur'}
                ],
                code:[
                    {required:true,message:'請(qǐng)輸入驗(yàn)證碼',trigger:'blur'},
                    {min:4,max:4,message:'驗(yàn)證碼長(zhǎng)度4位',trigger:'blur'}
                ],
            }
        }
    },
    methods:{
        submitLogin(){
            this.$refs.form.validate((valid)=>{
                if(valid){
                    axios.post('http://localhost:8081/demo',{username:"xxx",password:"123456",code:"1234"}).then((res)=>{
                        console.log(res)
                        
                    })
                }else{
                    this.$message.error('請(qǐng)輸入正確格式')
                    return false
                }    
            })
        }
    }
 
}
</script>
 
<style>
    .loginContainer{
        border-radius: 15px;
        background-clip: padding-box;
        margin:180px auto;
        width:350px;
        padding: 15px 35px 15px 35px;
        background: #a8dad5;
        border:1px solid #eaeaea;
        box-shadow: 0 0 25px #cac6c6;
    }
    .loginTitle{
        margin: 0px auto 40px auto;
        text-align: center;
    }
    .loginRemeber{
        text-align: left;
        margin:0px 0px 15px 0px;
    }
</style>

關(guān)于“Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“Vue項(xiàng)目如何創(chuàng)建首頁(yè)發(fā)送axios請(qǐng)求”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI