博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Slog50_支配vue框架初阶项目之博客网站-单页-客户端(浏览器)更新头像2
阅读量:6939 次
发布时间:2019-06-27

本文共 9373 字,大约阅读时间需要 31 分钟。

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

要成就一番事业 既要靠本事上位 又得懂拉拢站队


开发环境MacOS(High Sierra 10.13.5)

需要的信息和信息源:

开始编码

  • 首先,先理一下思路:
1.用户登陆、客户端(浏览器)登陆 ->2.向服务端发送一条信息,获取用户数据 ->3.服务端处理客户端发来的数据,返回相应的数据 ->4.客户端(浏览器)接收返回的数据 ->5.客户端(浏览器)解析返回的数据 ->6.客户端(浏览器)根据解析好的数据,进行业务处理(将处理好的数据路由到相应的前端的逻辑功能) ->7.客户端(浏览器)渲染页面
  • 上一篇文章,实现个头像的更新功能,但是需要重新登陆的时候,才会显示更新的图片
  • 这次要做的,就是提交更新后让图片马上更新成最新的图片
  • 考虑一下具体的实现逻辑,使用 vue.js框架双向数据流的功能,可以有下面几种方式:
  1. 客户端(浏览器)在提交图片给服务器成功之后,同时客户端(浏览器)把提交的图片覆盖本地的图片
  2. 客户端(浏览器)提交图片给服务器后,重新向服务器发送请求,获取最新的图片数据,页面上渲染最新的图片数据
  3. 客户端(浏览器)在选择了准备传送的图片之后,提交图片给服务器之前,页面渲染最新的图片
  • 选择第三种方法,我们要在选择图片的时候,同时渲染新的图片
  • 根据 ,使用 v-bin 绑定 图片的src,让我们可以在 client/signup.js 里可以动态修改 图片的src 的值,正因为 vue.js框架双向数据流的特性,当在 client/signup.js 修改 图片的src 的值的时候,页面上也会同时渲染新的图片
  • 更新后的完整代码

client/signup.js

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资源定位符赋值给图片的src,更新图片
  • 同时,我们需要更新 html文件,在html文件里使用 vue.js模版语法 v-bin

client/app.html

    
signin_ArthurSlog
  • 更新部分:

client/app.html

ArthurSlog_icon
  • 使用 v-bin 绑定了src的值之后,通过 imageSrc 这个对象,js文件 可以 html文件里面图片的 src的值
  • 现在,打开浏览器,输入 127.0.0.1:3000/app.html,点击 signin 按钮
  • 输入账号:ArthurSlog 密码:ArthurSlog,点击登陆
  • 成功登陆之后,点击 “选择文件” 按钮,选择一张你电脑里的图片,然后点击“打开”
  • 正常执行的情况下,你会发现,你的头像已经变成了你最新选取的图片了
  • 再点击 uploadfiles 按钮,观察 服务端终端,正常情况下成功接收到文件,并打印出文件信息
  • 刷新页面,点击 signin 按钮
  • 输入账号:ArthurSlog 密码:ArthurSlog,点击登陆
  • 正常情况下,头像已经更新为你最近更改的图片了
  • 至此,我们实现了客户端头像选取后即时更新的功能。

欢迎关注我的微信公众号 ArthurSlog

关注微信公众号“ArthurSlog”

如果你喜欢我的文章 欢迎点赞 留言

谢谢

转载地址:http://aksnl.baihongyu.com/

你可能感兴趣的文章
webBrowser 模拟登录
查看>>
t4 template multi file output
查看>>
深入理解Fsync
查看>>
剑道基础 - 冈宪次郎
查看>>
Leading and Trailing(数论/n^k的前三位)题解
查看>>
我的php笔记(一)
查看>>
vue.js学习之better-scroll封装的轮播图初始化失败
查看>>
去掉xcode编译warning:ld: warning: directory not found for option '-L
查看>>
杭电1702--ACboy needs your help again!
查看>>
web前端开发分享-css,js进阶篇
查看>>
安大校赛/异或运算一题。
查看>>
ANT build.xml文件详解
查看>>
MVC和观察者模式
查看>>
python 基本的序列和映射规则
查看>>
强制回收和IDisposable.Dispose方法
查看>>
mybatis plus条件构造器
查看>>
反射基础
查看>>
quick sort(重复数版)
查看>>
乌班图 root权限获取
查看>>
Java内部类
查看>>