欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用vue構(gòu)建一個(gè)上傳圖片表單

 更新時(shí)間:2017年07月04日 14:31:56   作者:Wenzi  
這篇文章主要為大家詳細(xì)介紹了使用vue構(gòu)建一個(gè)上傳圖片表單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

這篇博客也不知道起個(gè)什么名字比較好,畢竟剛開始學(xué)習(xí)vue,很多還不是很熟悉,一直在慢慢摸索中;之前也習(xí)慣了用jQuery寫js代碼,思維邏輯也要有個(gè)轉(zhuǎn)換的過程。

1. 轉(zhuǎn)變思維

使用vue編寫代碼,首先要做的就是轉(zhuǎn)換思維,vue是一個(gè)數(shù)據(jù)驅(qū)動(dòng)的框架,我們只需要操作數(shù)據(jù),數(shù)據(jù)變化后,vue會(huì)自動(dòng)改變DOM結(jié)構(gòu),而jQuery是直接操作DOM的。比如剛開始寫的代碼中犯的錯(cuò)誤,有一個(gè)頁面中的input標(biāo)簽是并列多個(gè)的,而且name屬性的值是自增的,那么我就用v-for循環(huán)下,把index填充進(jìn)去就行了,刪除的時(shí)候根據(jù)index再進(jìn)行刪除。于是代碼是這樣的:
html:

<div id="app">
 <ul>
 <li v-for="(item, index) in username">
 ${index}. <input type="text" :name="'sb['+index+']'" /> <a href="javascript:;" :index="index" @click="del">delete</a>
 </li>
 </ul>
 <a href="javascript:;" @click="add">add</a>
</div>

js:

var app = new Vue({
 el: '#app',
 delimiters : ['${', '}'],
 data: {
  username : [1, 2, 3] // 只要數(shù)組的下標(biāo),因此數(shù)值無所謂
 },
 methods : {
 // 添加選項(xiàng)
 add : function(){
  this.username.push(1);
 },

 // 刪除當(dāng)前選項(xiàng)
 del : function(e){
  var index = e.target.getAttribute('index'); // 獲取所在位置然后刪除
  this.username.splice(index, 1);
 }
 }
})

我們先在輸入框中輸入不同的內(nèi)容,然后刪除中間的某個(gè)選項(xiàng)。[demo1]
結(jié)果發(fā)現(xiàn),被刪除的永遠(yuǎn)是最后一個(gè)。這是為什么呢,我也是刪除數(shù)組了呀?我是看了官方文檔后才明白:用戶往輸入框內(nèi)輸入的內(nèi)容只保存在了DOM中,而我們是用vue中的username的下標(biāo)渲染的出來的DOM元素,我們并沒有保存用戶輸入的內(nèi)容。當(dāng)我們刪除了其中的某一項(xiàng)時(shí),username發(fā)生變化,導(dǎo)致DOM重新渲染,渲染后,最后一項(xiàng)就沒有了。
那么怎么修改才能真正的實(shí)現(xiàn)刪除某一項(xiàng)呢?我們只需要把用戶輸入的內(nèi)容保存到username數(shù)組中即可:

html:

<div id="app">
 <ul>
 <li v-for="(item, index) in username">
 ${index}. <input type="text" :name="'sb['+index+']'" :value="item" > <a href="javascript:;" :index="index" @click="del">delete</a>
 </li>
 </ul>
 <a href="javascript:;" @click="add">add</a>
</div>

js:

var app = new Vue({
 el: '#app',
 delimiters : ['${', '}'],
 data: {
  username : ['wenzi', 'xxxx', 'yyyy'] // 只要數(shù)組的下標(biāo),因此數(shù)值無所謂
 },
 methods : {
 // 添加選項(xiàng)
 add : function(){
  this.username.push(''); // 新添加的輸入框?yàn)榭?
 },

 // 刪除當(dāng)前選項(xiàng)
 del : function(e){
  var index = e.target.getAttribute('index'); // 獲取所在位置然后刪除
  this.username.splice(index, 1);
 }
 }
})

再來看下效果:[demo2]

2. 上傳圖片

剛開始時(shí),使用的jQuery的插件fileupload,功能很全,當(dāng)我為file標(biāo)簽綁定上change事件后,然后再調(diào)用該插件進(jìn)行圖片上傳,總是會(huì)出現(xiàn)意想不到的bug,比如我先對(duì)圖片格式進(jìn)行限制,只能上傳png格式的圖片,可是有時(shí)候jpg格式的也能上傳上去;png格式的圖片,英文名稱無法上傳,先傳個(gè)中文名稱,然后就可以再上傳英文呢名稱的了。
后來發(fā)現(xiàn)html5下的formData屬性,能非常方便的上傳圖片,而且同時(shí)還能上傳其他的參數(shù),一小段代碼即可搞定:

// 上傳圖片,綁定change事件
uppic : function(e){
 var file = e.target.files[0]; // 每次只允許上傳一張圖片,因此只取[0]

 // 判斷圖片格式
 if( file.type!='image/png' ){ 
  alert('圖片格式不正確');
  e.target.files.length = 0;
  $(e.target).val('');
  return false; 
 }

 // 使用formData組裝數(shù)據(jù)
 var formData = new FormData();
 formData.append('pic', $(e.target)[0].files[0]); // 文件數(shù)據(jù)
 formData.append('flag', '1'); // 其他的一些參數(shù)
 $.ajax({// ajax上傳
  url: 'xxxxx.php',
  type: 'POST',
  cache: false,
  data: formData,
  processData: false,
  contentType: false
 }).done(function(result) {
  console.log('上傳完成');
 });
}

3. 總結(jié)

現(xiàn)在也是剛開始學(xué)習(xí)vue,代碼肯定比較爛,最重要的還是轉(zhuǎn)變思維吧!

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解vue數(shù)據(jù)渲染出現(xiàn)閃爍問題

    詳解vue數(shù)據(jù)渲染出現(xiàn)閃爍問題

    本篇文章主要介紹了vue數(shù)據(jù)渲染出現(xiàn)閃爍問題,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-06-06
  • vuejs如何解決瀏覽器切換頁面后setInterval計(jì)時(shí)器停止執(zhí)行的問題

    vuejs如何解決瀏覽器切換頁面后setInterval計(jì)時(shí)器停止執(zhí)行的問題

    setinterval()是定時(shí)調(diào)用的函數(shù),可按照指定的周期(以毫秒計(jì))來調(diào)用函數(shù)或計(jì)算表達(dá)式,這篇文章主要給大家介紹了關(guān)于vuejs如何解決瀏覽器切換頁面后setInterval計(jì)時(shí)器停止執(zhí)行的問題,需要的朋友可以參考下
    2024-01-01
  • Vue子組件props從父組件接收數(shù)據(jù)并存入data

    Vue子組件props從父組件接收數(shù)據(jù)并存入data

    這篇文章主要介紹了Vue子組件props從父組件接收數(shù)據(jù)并存入data的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • ElementUI組件Dialog彈窗再次打開表單仍顯示上次數(shù)據(jù)的問題

    ElementUI組件Dialog彈窗再次打開表單仍顯示上次數(shù)據(jù)的問題

    這篇文章主要介紹了ElementUI組件Dialog彈窗再次打開表單仍顯示上次數(shù)據(jù)的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Vue.js和Vue.runtime.js區(qū)別淺析

    Vue.js和Vue.runtime.js區(qū)別淺析

    這篇文章主要介紹了Vue.js和Vue.runtime.js區(qū)別淺析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • vue項(xiàng)目之webpack打包靜態(tài)資源路徑不準(zhǔn)確的問題

    vue項(xiàng)目之webpack打包靜態(tài)資源路徑不準(zhǔn)確的問題

    這篇文章主要介紹了vue項(xiàng)目之webpack打包靜態(tài)資源路徑不準(zhǔn)確的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue3.0中ref與reactive的區(qū)別及使用場(chǎng)景分析

    vue3.0中ref與reactive的區(qū)別及使用場(chǎng)景分析

    ref與reactive都是Vue3.0中新增的API,用于響應(yīng)式數(shù)據(jù)的處理,這篇文章主要介紹了vue3.0中ref與reactive的區(qū)別及使用,需要的朋友可以參考下
    2023-08-08
  • element多個(gè)表單校驗(yàn)的實(shí)現(xiàn)

    element多個(gè)表單校驗(yàn)的實(shí)現(xiàn)

    在項(xiàng)目中,經(jīng)常會(huì)遇到表單檢驗(yàn),在這里我分享在實(shí)際項(xiàng)目中遇到多個(gè)表單同時(shí)進(jìn)行校驗(yàn)以及我的解決方法,感興趣的可以了解一下
    2021-05-05
  • vue中vue-router安裝與配置方法步驟詳解

    vue中vue-router安裝與配置方法步驟詳解

    vue-router是Vue.js官方的路由插件,它和vue.js是深度集成的,適合用于構(gòu)建單頁面應(yīng)用,下面這篇文章主要給大家介紹了關(guān)于vue中vue-router安裝與配置方法的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • vue項(xiàng)目代碼格式規(guī)范設(shè)置參考指南

    vue項(xiàng)目代碼格式規(guī)范設(shè)置參考指南

    這篇文章主要給大家介紹了關(guān)于vue3簡(jiǎn)單封裝input組件和統(tǒng)一表單數(shù)據(jù)的相關(guān)資料,不管你學(xué)習(xí)哪一門編程語言,相信大家都會(huì)略化這一部分,需要的朋友可以參考下
    2022-05-05

最新評(píng)論