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

bootstrap-wysiwyg結(jié)合ajax實(shí)現(xiàn)圖片上傳實(shí)時(shí)刷新功能

 更新時(shí)間:2016年05月27日 16:12:02   作者:Acce1erator  
這篇文章主要為大家詳細(xì)介紹了bootstrap-wysiwyg結(jié)合ajax實(shí)現(xiàn)圖片上傳實(shí)時(shí)刷新功能,感興趣的小伙伴們可以參考一下

最近由于項(xiàng)目需求,要實(shí)現(xiàn)一個(gè)前端文本編輯框,附帶圖片上傳實(shí)時(shí)查看的功能。比較了網(wǎng)上的幾款插件,首先是百度的UEitor,發(fā)現(xiàn)該框架過于龐大,一個(gè)小框架引入如此多的文件并不是我想看到的;其次是jQuery的easyUI,雖然個(gè)人版的是免費(fèi)的,但是項(xiàng)目屬于公司業(yè)務(wù),似乎用商業(yè)版的框架并不妥??紤]到項(xiàng)目的前端主要就是在bootstrap的基礎(chǔ)上構(gòu)建起來的,最終選用了bootstrap-wysiwyg插件,它非常的精簡,輕巧而且擴(kuò)展性強(qiáng)。

引入bootstrap-wysiwyg并且實(shí)現(xiàn)文本編輯功能十分的便捷,但是,我注意到,圖片上傳是用fileapi實(shí)現(xiàn)的。對(duì)于大多數(shù)網(wǎng)站,雖然用FileApi實(shí)現(xiàn)無上傳預(yù)覽用戶體驗(yàn)非常好,但是真正存入數(shù)據(jù)庫的時(shí)候,我們還是希望能夠存儲(chǔ)圖片的在服務(wù)器的靜態(tài)路徑,而并非字符串化的圖片。簡而言之,我們需要對(duì)bootstrap-wysiwyg(以下簡稱WY)做稍許改寫。

首先我們來觀察下頁面上圖片控件,其它的控件略過,查一下源碼,很容易發(fā)現(xiàn)如下代碼:

<div class="btn-group">
 <a class="btn" title="Insert picture (or just drag & drop)" id="pictureBtn">
 <i class="icon-picture"></i></a>
  <input type="file" data-role="magic-overlay" 
   data-target="#pictureBtn"
  data-edit="insertImage" />
</div>

做一下說明,data-role,data-target屬性是bootstrap中預(yù)定義的事件,在這里我們可以理解為布局相關(guān),不用考慮。關(guān)鍵點(diǎn)來了,第三個(gè)屬性data-edit,bootstrap中并沒有這一事件,觀察bootstrap-wysiwyg.js,可以發(fā)現(xiàn)這樣一些代碼:

toolbar.find('input[type=file][data-' + options.commandRole + ']')
   .change( ...
   ...
commandRole : 'edit',

也就是說,該屬性其實(shí)是為了方便選擇器而實(shí)現(xiàn)的,相當(dāng)于給圖片按鈕添加了監(jiān)聽器事件。

我們接著研究一下WY圖片預(yù)覽的實(shí)現(xiàn),第一步,就像上面代碼展示的一樣,監(jiān)聽器捕捉到fileInput的change事件,做出響應(yīng),調(diào)用insertFiles函數(shù)

restoreSelection();
if (this.type === 'file' && this.files && this.files.length > 0) {
 insertFiles(this.files);
}
saveSelection();
his.value = '';

找到insertFiles函數(shù)

insertFiles = function (files) {
  editor.focus();
  $.each(files, function (idx, fileInfo) {
   if (/^image\//.test(fileInfo.type)) {
   $.when(readFileIntoDataUrl(fileInfo)).done(function (dataUrl) {
    execCommand('insertimage', dataUrl);
   }).fail(function (e) {
    options.fileUploadError("file-reader", e);
   });
   } else {
   options.fileUploadError("unsupported-file-type", fileInfo.type);
   }
  });
  }

我們注意到它使用了jQuery的$.Deferred()方法,先調(diào)用了一個(gè)readFileIntoDataUrl方法,成功之后通過自封裝的execCommand方法實(shí)現(xiàn)將圖片輸出到文本框。該圖片其實(shí)就是一個(gè)<img>標(biāo)簽,只不過src屬性是用字符串表示的圖片。所以我們要做的其實(shí)是在監(jiān)聽器觸發(fā)之后,將文件上傳,獲得圖片的src,再把鏈接交給之后的execCommand方法。

由于筆者對(duì)Deferred并不是特別熟悉,所以還是采用更為通常的callback模式

觀察ajaxFileUpload的調(diào)用方式:

$.ajaxFileUpload({
  url : ...,
  secureurl : false,
  fileElementId : ...,
  dataType : "json",
  success : function(obj) {
   ...
  },
  error : function() {
   ...
  }
  });

有兩個(gè)必選的屬性,url和fileElementId,為了保持依賴的正確性,重寫ajaxFileUpload是不可取的。但是由于WY的控件是監(jiān)聽器實(shí)現(xiàn)的,所以通過函數(shù)將參數(shù)傳過去是不現(xiàn)實(shí)的,所以我們需要自己對(duì)輸入框定義一些屬性來達(dá)到目的。

在fileInput中添加一些屬性

<input type="file" id="pictureInput" name="picture"
   data-role="magic-overlay" data-target="#pictureBtn"
   data-edit="insertImage" action="..." />

id 用作 fileElementId,name屬性也是必須的,主要是為了后臺(tái)取值指名,action是圖片需要提交到的url

在bootstrap-wysiwyg.js中定義一個(gè)函數(shù)名為uploadFileToServer,函數(shù)格式如下:

var uploadFileToServer = function(id, action, callback) {
 $.ajaxFileUpload({
  url : action,
  secureurl : false,
  fileElementId : id,
  dataType : 'json',
  success : function(obj) {
  if (obj.status) {
   callback(obj.imgsrc);
  } else
   options.fileUploadError("server-internal-exception",
    obj.message);
  },
  error : function() {
  options.fileUploadErroe("upload-failure", "");
  }
 });

將insertFiles方法作改寫如下:

insertFiles = function(files, id, action) {
  editor.focus();
  $.each(files, function(idx, fileInfo) {
  if (/^image\//.test(fileInfo.type)) {
   /*
   * $.when(readFileIntoDataUrl(fileInfo)).done(function(dataUrl) {
   * execCommand('insertimage', dataUrl); }).fail(function(e) {
   * options.fileUploadError("file-reader", e); });
   */
   uploadFileToServer(id, action, function(src) {
   execCommand('insertimage', src);
   });
  } else {
   options.fileUploadError("unsupported-file-type",
    fileInfo.type);
  }
  });

同時(shí)對(duì)監(jiān)聽器做出一定的修改,以便拿到必要的屬性

toolbar.find('input[type=file][data-' + options.commandRole + ']')
  .change(
   function() {
    restoreSelection();
    if (this.type === 'file' && this.files
     && this.files.length > 0) {
     insertFiles(this.files, $(this).attr('id'),
      $(this).attr('action'));
    }
    saveSelection();
    this.value = '';
    });

主要是增加了兩個(gè)參數(shù)位置。

如此,改寫便完成了,注意,要確保正確執(zhí)行,請(qǐng)?jiān)诳丶耙胊jaxFileUpload.js.

如果大家還想深入學(xué)習(xí),可以點(diǎn)擊這里進(jìn)行學(xué)習(xí),再為大家附3個(gè)精彩的專題:

Bootstrap學(xué)習(xí)教程

Bootstrap實(shí)戰(zhàn)教程

Bootstrap插件使用教程

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

相關(guān)文章

  • JS組件Bootstrap dropdown組件擴(kuò)展hover事件

    JS組件Bootstrap dropdown組件擴(kuò)展hover事件

    bootstrap的下拉組件,需要點(diǎn)擊click時(shí),方可展示下拉列表。因此對(duì)于喜歡簡單少操作的大家來說,點(diǎn)擊一下多少帶來不便,因此,引入hover監(jiān)聽,鼠標(biāo)經(jīng)過自動(dòng)展示下拉框。這篇文章主要介紹了JS組件Bootstrap dropdown組件擴(kuò)展hover事件,感興趣的小伙伴們可以參考一下
    2016-04-04
  • 微信小程序使用audio組件播放音樂功能示例【附源碼下載】

    微信小程序使用audio組件播放音樂功能示例【附源碼下載】

    這篇文章主要介紹了微信小程序使用audio組件播放音樂功能,結(jié)合實(shí)例形式分析了微信小程序audio組件播放在線音樂相關(guān)操作技巧,并附帶源碼供讀者下載參考,需要的朋友可以參考下
    2017-12-12
  • Bootstrap縮略圖的創(chuàng)建方法

    Bootstrap縮略圖的創(chuàng)建方法

    這篇文章主要介紹了Bootstrap縮略圖的創(chuàng)建方法,教大家如何實(shí)現(xiàn)Bootstrap縮略圖,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • JavaScript中解決多瀏覽器兼容性23個(gè)問題的快速解決方法

    JavaScript中解決多瀏覽器兼容性23個(gè)問題的快速解決方法

    下面小編就為大家?guī)硪黄狫avaScript中解決多瀏覽器兼容性23個(gè)問題的快速解決方法。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-05-05
  • Bootstrap modal 多彈窗之疊加關(guān)閉陰影遮罩問題的解決方法

    Bootstrap modal 多彈窗之疊加關(guān)閉陰影遮罩問題的解決方法

    這里也會(huì)遇到一次性關(guān)閉所有modal引起陰影遮罩的問題,也就是所有modal都關(guān)閉了,但是主頁面仍然被陰影遮罩。下面通過本文給大家分享解決方案,需要的朋友參考下吧
    2017-02-02
  • JavaScript實(shí)現(xiàn)伸縮二級(jí)菜單

    JavaScript實(shí)現(xiàn)伸縮二級(jí)菜單

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)伸縮二級(jí)菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • JavaScript實(shí)現(xiàn)打地鼠小游戲

    JavaScript實(shí)現(xiàn)打地鼠小游戲

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)打地鼠小游戲的相關(guān)代碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • 微信小程序頁面調(diào)用自定義組件內(nèi)的事件詳解

    微信小程序頁面調(diào)用自定義組件內(nèi)的事件詳解

    這篇文章主要介紹了微信小程序頁面調(diào)用自定義組件內(nèi)的事件詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • 微信小程序swiper-dot中的點(diǎn)如何改成滑塊詳解

    微信小程序swiper-dot中的點(diǎn)如何改成滑塊詳解

    swiper組件是滑塊視圖容器,這篇文章主要給大家介紹了關(guān)于微信小程序swiper-dot中的點(diǎn)如何改成滑塊的相關(guān)資料,實(shí)現(xiàn)以后的效果還是不錯(cuò)的,需要的朋友可以參考下
    2021-07-07
  • JavaScript數(shù)組合并案例講解

    JavaScript數(shù)組合并案例講解

    這篇文章主要介紹了JavaScript數(shù)組合并案例講解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08

最新評(píng)論