Slog50_支配vue框架初階項目之博客網站-單頁-客戶端(瀏覽器)更新頭像2

  • ArthurSlog
  • SLog-50
  • Year·1
  • Guangzhou·China
  • Aug 26th 2018

要成就一番事業 既要靠本事上位 又得懂拉攏站隊css


開發環境MacOS(High Sierra 10.13.5)

須要的信息和信息源:

開始編碼

  • 首先,先理一下思路:
1.用戶登錄、客戶端(瀏覽器)登錄 ->
2.向服務端發送一條信息,獲取用戶數據 ->
3.服務端處理客戶端發來的數據,返回相應的數據 ->
4.客戶端(瀏覽器)接收返回的數據 ->
5.客戶端(瀏覽器)解析返回的數據 ->
6.客戶端(瀏覽器)根據解析好的數據,進行業務處理
(將處理好的數據路由到相應的前端的邏輯功能) ->
7.客戶端(瀏覽器)渲染頁面
  • 上一篇文章,實現個頭像的更新功能,可是須要從新登錄的時候,纔會顯示更新的圖片
  • 此次要作的,就是提交更新後讓圖片立刻更新成最新的圖片
  • 考慮一下具體的實現邏輯,使用 vue.js框架雙向數據流的功能,能夠有下面幾種方式:
  1. 客戶端(瀏覽器)在提交圖片給服務器成功以後,同時客戶端(瀏覽器)把提交的圖片覆蓋本地的圖片
  2. 客戶端(瀏覽器)提交圖片給服務器後,從新向服務器發送請求,獲取最新的圖片數據,頁面上渲染最新的圖片數據
  3. 客戶端(瀏覽器)在選擇了準備傳送的圖片以後,提交圖片給服務器以前,頁面渲染最新的圖片
  • 選擇第三種方法,咱們要在選擇圖片的時候,同時渲染新的圖片
  • 根據 vue模版語法 v-bind,使用 v-bin 綁定 圖片的src,讓咱們能夠在 client/signup.js 裏能夠動態修改 圖片的src 的值,正由於 vue.js框架雙向數據流的特性,當在 client/signup.js 修改 圖片的src 的值的時候,頁面上也會同時渲染新的圖片
  • 更新後的完整代碼

client/signup.jshtml

var host = 'http://127.0.0.1:3000/';

var signup_container = new Vue({
  el: '#signup-container',
  data: {
    name_signin: '',
    password_signin: '',
    name: '',
    password: '',
    repassword: '',
    firstname: '',
    lastname: '',
    birthday: '',
    sexs: ['male', 'female'],
    currentSex: 'male',
    ages: ['1', '2', '3', '4', '5', '6', '7', '8',
      '9', '10', '11', '12', '13', '14', '15', '16', '17', '18'],
    currentAge: '18',
    wechart: '',
    qq: '',
    email: '',
    contury: '',
    address: '',
    phone: '',
    websize: '',
    github: '',
    bio: '',
    commits: null,
    pagestate: '0',
    image: '',
    imageSrc: '/image/ArthurSlog_icon.jpg'
  },
  methods: {
    uploadfiles: function () {
      var xhr = new XMLHttpRequest()
      var fd = new FormData()

      var self = this
      xhr.open('POST', host + 'uploadfiles', true)

      xhr.onload = function () {
        //self.commits = xhr.responseText
        self.commits = xhr.responseText
      }
      fd.append('myFile', this.image)
      xhr.send(fd)
    },
    filesChange: function (event) {
      this.image = event.target.files[0]
      this.imageSrc = window.URL.createObjectURL(event.target.files[0])
    },
    return_index: function () {
      this.pagestate = '0'
    },
    signin_index: function () {
      this.pagestate = '1'
    },
    signup_index: function () {
      this.pagestate = '2'
    },
    signin: function () {
      //當點擊登錄的時候,在頁面上渲染從服務端返回的數據,把其餘的部分隱藏掉
      this.pagestate = '3'

      var xhr = new XMLHttpRequest()

      var self = this

      xhr.open('GET', host + 'signin?' + 'name=' + self.name_signin + '&password=' + self.password_signin, true)

      xhr.onload = function () {
        //self.commits = xhr.responseText
        var myObj = JSON.parse(xhr.responseText);
        self.commits = myObj
      }

      xhr.send()
    },
    addUser: function () {
      //當點擊註冊的時候,在頁面上渲染從服務端返回的數據,把其餘的部分隱藏掉
      this.pagestate = '3'

      var xhr = new XMLHttpRequest()

      var self = this
      xhr.open('GET', host + 'signup?' + 'name=' + self.name + '&password=' + self.password + '&firstname=' +
        self.firstname + '&lastname=' + self.lastname + '&birthday=' + self.birthday
        + '&sex=' + self.currentSex + '&age=' + self.currentAge + '&wechart=' + self.wechart
        + '&qq=' + self.qq + '&email=' + self.email + '&contury=' + self.contury
        + '&address=' + self.address + '&phone=' + self.phone + '&websize=' + self.websize
        + '&github=' + self.github + '&bio=' + self.bio, true)

      xhr.onload = function () {
        self.commits = xhr.responseText
      }

      xhr.send()
    }
  }
})
  • 更新的部分:

server/index.js前端

//data部分
data: {
    imageSrc: '/image/ArthurSlog_icon.jpg'
}
//methods部分
methods: {
    filesChange: function (event) {
        this.image = event.target.files[0]
        this.imageSrc = URL.createObjectURL(event.target.files[0])
    }
}
  • URL.createObjectURL(),使用這個方法生成一個 URL資源定位符賦值給圖片的src,更新圖片
  • 同時,咱們須要更新 html文件,在html文件裏使用 vue.js模版語法 v-bin

client/app.htmlvue

<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <link rel="stylesheet" type="text/css" href="./css/style.css">
    <!-- 開發環境版本,包含了有幫助的命令行警告 -->
    <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
    <title>signin_ArthurSlog</title>
</head>

<body>

    <div id="signup-container">
        <template class="container" v-if="pagestate === '0'">
            <div>This is index's page by ArthurSlog</div>
            <br>
            <button v-on:click="signin_index">Signin</button>
            <br>
            <button v-on:click="signup_index">Signup</button>
        </template>


        <template id="Signin" v-else-if="pagestate === '1'">
            <div>This is signin's page by ArthurSlog</div>
            <p>Singin</p>
            <form id="form1" v-on:submit.prevent="signin">
                <br>
                <div>
                    Account: {{ name_signin }}
                    <br>
                    <input type="text" v-model="name_signin" placeholder="username">
                </div>
                <br>

                <br>
                <div>
                    Password: {{ password_signin }}
                    <br>
                    <input type="text" v-model="password_signin" placeholder="password">
                </div>
                <br>
                <input type="submit" value="登錄">
            </form>
            <br>
            <button v-on:click="return_index">ReturnIndex</button>
        </template>


        <template id="Signup" v-else-if="pagestate === '2'">
            <div>This is signup's page by ArthurSlog</div>
            <p>Singup</p>

            <form id="form2" v-on:submit.prevent="addUser">

                <br>
                <div>
                    Account: {{ name }}
                    <br>
                    <input type="text" v-model="name" placeholder="username">
                </div>
                <br>

                <br>
                <div>
                    Password: {{ password }}
                    <br>
                    <input type="text" v-model="password" placeholder="password">
                </div>
                <br>

                <br>
                <div>
                    Again Password: {{ repassword }}
                    <br>
                    <input type="text" v-model="repassword" placeholder="repassword">
                </div>
                <br>


                <br>
                <div>
                    First Name: {{ firstname }}
                    <br>
                    <input type="text" v-model="firstname" placeholder="firstname">
                </div>
                <br>

                <br>
                <div>
                    Last Name: {{ lastname }}
                    <br>
                    <input type="text" v-model="lastname" placeholder="lastname">
                </div>
                <br>

                <br>
                <div>
                    Birthday: {{ birthday }}
                    <br>
                    <input type="text" v-model="birthday" placeholder="2000/08/08">
                </div>
                <br>

                <br>
                <div>
                    <span>Sex: {{ currentSex }}</span>
                    <br>
                    <input type="radio" id="sex" value="male" v-model="currentSex">
                    <label for="sex">male</label>
                    <br>
                    <input type="radio" id="sex" value="female" v-model="currentSex">
                    <label for="sex">female</label>
                </div>
                <br>

                <br>
                <div>
                    <span>Age: {{ currentAge }}</span>
                    <br>
                    <select v-model="currentAge" id="age">
                        <option disabled value="">Select</option>
                        <option v-for="age in ages">{{ age }}</option>
                    </select>
                </div>
                <br>

                <br>
                <div>
                    Wechart: {{ wechart }}
                    <br>
                    <input type="text" v-model="wechart" placeholder="wechart's name">
                </div>
                <br>

                <br>
                <div>
                    QQ: {{ qq }}
                    <br>
                    <input type="text" v-model="qq" placeholder="12345678">
                </div>
                <br>

                <br>
                <div>
                    Email: {{ email }}
                    <br>
                    <input type="text" v-model="email" placeholder="12345678@qq.com">
                </div>
                <br>

                <br>
                <div>
                    Contury: {{ contury }}
                    <br>
                    <input type="text" v-model="contury" placeholder="China">
                </div>
                <br>

                <br>
                <div>
                    Address: {{ address }}
                    <br>
                    <input type="text" v-model="address" placeholder="Guangzhou">
                </div>
                <br>

                <br>
                <div>
                    Phone: {{ phone }}
                    <br>
                    <input type="text" v-model="phone" placeholder="138********">
                </div>
                <br>

                <br>
                <div>
                    Websize: {{ websize }}
                    <br>
                    <input type="text" v-model="websize" placeholder="xxx.com">
                </div>
                <br>

                <br>
                <div>
                    Github: {{ github }}
                    <br>
                    <input type="text" v-model="github" placeholder="Github's URl">
                </div>
                <br>

                <br>
                <div>
                    Bio: {{ bio }}
                    <br>
                    <input type="text" v-model="bio" placeholder="This is the world~">
                </div>
                <br>

                <br>
                <input type="submit" value="完成註冊">
            </form>

            <button v-on:click="addUser">addUser</button>
            <br>
            <button v-on:click="return_index">ReturnIndex</button>
            <br>
        </template>

        <template id="returnResult" v-else-if="pagestate === '3'">
            <div>
                <img id="ArthurSlog_icon" v-bind:src="imageSrc" alt="ArthurSlog_icon" />
            </div>
            <div>
                <div>Uploading {{ image }} files...</div>
                <br>
                <input type="file" v-on:change="filesChange">
                <br>
                <button v-on:click="uploadfiles">uploadfiles</button>
            </div>
            <div id="signinResult">
                <div v-for="(value, key) in commits">
                    {{ key }}: {{ value }}
                </div>
            </div>
        </template>
    </div>
    <script src="./js/signup.js"></script>
</body>

</html>
  • 更新部分:

client/app.htmlgit

<div>
    <img id="ArthurSlog_icon" v-bind:src="imageSrc" alt="ArthurSlog_icon" />
</div>
  • 使用 v-bin 綁定了src的值以後,經過 imageSrc 這個對象,js文件 能夠 html文件裏面圖片的 src的值
  • 如今,打開瀏覽器,輸入 127.0.0.1:3000/app.html,點擊 signin 按鈕
  • 輸入帳號:ArthurSlog 密碼:ArthurSlog,點擊登錄
  • 成功登錄以後,點擊 「選擇文件」 按鈕,選擇一張你電腦裏的圖片,而後點擊「打開」
  • 正常執行的狀況下,你會發現,你的頭像已經變成了你最新選取的圖片了
  • 再點擊 uploadfiles 按鈕,觀察 服務端終端,正常狀況下成功接收到文件,並打印出文件信息
  • 刷新頁面,點擊 signin 按鈕
  • 輸入帳號:ArthurSlog 密碼:ArthurSlog,點擊登錄
  • 正常狀況下,頭像已經更新爲你最近更改的圖片了
  • 至此,咱們實現了客戶端頭像選取後即時更新的功能。

歡迎關注個人微信公衆號 ArthurSlog

關注微信公衆號「ArthurSlog」

若是你喜歡個人文章 歡迎點贊 留言

謝謝

相關文章
相關標籤/搜索