日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

[ WebUpload ] WebUpload 插件初始化问题

發布時間:2023/12/29 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [ WebUpload ] WebUpload 插件初始化问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

WebUpload 插件初始化問題

本文主要針對WebUpload 文件上傳插件在初始化多個時,插件自定義按鈕顯示位置錯位導致點擊失效的問題提供解決方案。(亦可描述為webupload插件在父容器display屬性為none的情況下初始化位置異常)

官網

目錄

  • WebUpload 插件初始化問題
    • 目錄
    • 實際案例
    • 源碼分析
    • 參考
    • 感謝


實際案例

1、基于avalon開發的前端界面

  • ms-if =”布爾表達式” 為true,表示生成下方頁面文本;反之,不生成

  • ms-visible=”布爾表達式” 為true,表示顯示下方頁面文本(display:block);反之,不顯示(display:none)

2、解決方法

  • 初始化前先利用ms-if顯示webuploader綁定的容器部分,再執行初始化方法
  • 或者利用ms-if每次動態生成頁面部分代碼,再執行初始化方法
  • 利用ms-visible控制顯隱,結合數組array接收Webuploader.create({…})生成的插件對象,在界面顯示后(display:block),利用循環執行uploader內部函數refresh();

前兩種方法相似,只是控制動態生成的文本域不同
第三種最優,利用webuploader內置函數refresh函數,對于界面資源利用更佳
核心是初始化在dom顯示之后執行,否則,refresh函數需要dom顯示之后執行!

/*** 預案資源文件管理*/RES_MAN: {/*** 初始化*/init: function () {this.createWebUploader(0);this.createWebUploader(1);},/*** webUoloader對象容器*/uploader: [],/*** 文件資源ID*/resId:[],/*** 創建文件上傳容器*/createWebUploader: function (index) {var resMan = this;var dropBox = $('#' + 'uploadBox' + index);var ipt = $('#' + 'filePicker' + index);resMan.uploader[index] = WebUploader.create({// 選完文件后,是否自動上傳。auto: true,// swf文件路徑swf: capsule.stringUtil.addPreUrl("/js/lib/webuploader/dist/Uploader.swf"),//指定Drag And Drop拖拽的容器dnd: $('#' + 'uploadBox' + index),// 文件接收服務端。server: capsule.stringUtil.addPreUrl("/data/plan/main/uploadPlanFile",{type:index}),// 選擇文件的按鈕??蛇x。// 內部根據當前運行是創建,可能是input元素,也可能是flash.pick: ipt,accept: {// 只允許選擇圖片文件。title: 'Images',extensions: 'jpg,jpeg,png',mimeTypes: 'image/jpg,image/jpeg,image/png'//修改這行,優化選擇文件界面開啟效率},// 不壓縮image, 默認如果是jpeg,文件上傳前會壓縮一把再上傳!resize: false});//其他事件監聽},//其他界面樣式控制.../*** 刷新布局定位*/refresh:function(){$.each(this.uploader,function(i,plugin){plugin.refresh();});}

源碼分析

對于display:none的dom元素,offset方法獲取到的值如下:

由于界面一開始是隱藏狀態進行初始化的,界面初始化兩個插件后:


由于絕對定位導致的的相對定位生成差異
兩個按鈕雖然css屬性一樣,確并沒有重疊,細致的原因未去研究,有興趣的可以看下css絕對的定位相關的介紹

可以看到,兩個插件自動生成的offset都是0,采用上述方案優化js邏輯后:

建議

1、如果js邏輯沒有問題,但是問題依然沒有解決,本人遇到的是由于avalon渲染需要時間導致的,因此加了個延時,確保dom渲染完畢,再執行refresh方法即可
2、對于每次初始化控件,對界面資源的使用略顯浪費,建議控制顯示和隱藏,在界面初始加載的時候進行webuploader插件的初始化,初始化完畢后,點擊顯示后,利用延時確保dom渲染完畢后遍歷uplader[],執行refresh,重新定位更佳。

/*** 確保下載容器display屬性不為none*/setTimeout(function(){PageHelper.RES_MAN.refresh();},1000);

參考

WebUploader初始化時的缺陷及處理方法
webuploader插件,我踩得坑

感謝

@ssq小伙伴的幫助!

總結

以上是生活随笔為你收集整理的[ WebUpload ] WebUpload 插件初始化问题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 黑人巨大猛烈捣出白浆 | 国产黄色高清 | 成人免费观看在线视频 | 91少妇丨porny丨 | 成人精品综合 | 色综合久久久无码中文字幕波多 | 91爱视频 | 黑人巨大精品欧美一区二区免费 | 蜜臀久久久久久999 大陆熟妇丰满多毛xxxⅹ | 欧美激情四区 | 国产一区中文 | 亚洲国产精华液网站w | 欧美爱爱小视频 | 国产裸体视频 | 久久国产精品免费视频 | 美女免费网站 | 成年人免费看视频 | 懂色av成人一区二区三区 | 激情丁香网 | 台湾性生生活1 | aⅴ在线免费观看 | 精品人妻无码一区二区三区蜜桃一 | av免费播放 | 丰满少妇中文字幕 | 网站在线播放 | 91精品国自产在线观看 | 侵犯女教师一区二区三区 | 欧美激情久久久久久久 | 亚洲综合图色 | 日韩毛片在线观看 | 日本乱偷中文字幕 | 国产精品23p| 女大学生的家政保姆初体验 | 蜜桃一区二区三区 | 日本美女久久久 | 亚洲欧洲天堂 | 亚洲第一在线视频 | 欧美特黄一级视频 | 欧美bbw视频| 老熟妇高潮一区二区三区 | 国产免费成人 | 中文字字幕在线中文 | 伊人日日夜夜 | 欧美国产高潮xxxx1819 | www狠狠| 性色欲情网站iwww九文堂 | 又污又黄又爽的网站 | 高清日韩一区二区 | 夜夜骑夜夜 | 国产精品久线在线观看 | 日韩高清久久 | 337p粉嫩大胆噜噜噜噜69影视 | 久久免费视频1 | 男女在楼梯上高潮做啪啪 | 我不卡一区二区 | 91综合在线| 水蜜桃亚洲精品 | 亚洲性综合 | aaaa毛片| 少妇人妻真实偷人精品视频 | 亚洲欧美天堂网 | 性久久久久久久久久久久 | 黄色片免费网站 | 重口味av| 奶罩不戴乳罩邻居hd播放 | 欧美日韩一级视频 | 中文字幕一区二区人妻在线不卡 | 成人性生交大片免费看中文 | 日韩在线一卡二卡 | 就去吻综合 | 神马影院午夜伦理 | 成人精品三级av在线看 | 国产精品自拍偷拍视频 | 日韩资源在线 | 国产一级片免费在线观看 | av电影中文字幕 | 国产亚洲在线观看 | 捆绑无遮挡打光屁股调教女仆 | 日本一区二区三区欧美 | 91精品日韩| 久久久久久久久影院 | 日韩中文字幕不卡 | 午夜精品福利在线观看 | 久久久久久久久免费 | 理论片一区| 变态 另类 国产 亚洲 | 国产在线精品福利 | 美女又黄又免费的视频 | 国产美女久久久久久 | 免费看日韩 | 96国产视频| 伊人影视久久 | 国产无遮挡呻吟娇喘视频 | 91艹 | 久久伊人av | 国产无遮挡一区二区三区毛片日本 | 女人下面流白浆的视频 | 亚洲狼人综合 | 四虎影视最新网址 |