[TOC]
# 多文件上傳插件(bootstrap-fileinput)
## 一、插件介紹
文件上傳控件bootstrap-fileinput的使用
https://www.cnblogs.com/parker-yu/p/7207071.html
JS組件系列——Bootstrap文件上傳組件:bootstrap fileinput
https://www.cnblogs.com/landeanfen/p/5007400.html
源碼以及API地址:
bootstrap-fileinput源碼:https://github.com/kartik-v/bootstrap-fileinput
bootstrap-fileinput在線API:http://plugins.krajee.com/file-input
bootstrap-fileinput Demo展示:http://plugins.krajee.com/file-basic-usage-demo
## 二、整合TP5
### 1、插件位置
~~~
static\admin\plugins\bootstrap-fileinput
~~~
### 2、引入文件
~~~
<input id="file-zh" name="file-zh[]" type="file" multiple>
<link href="__ADMIN__/plugins/bootstrap-fileinput/css/fileinput.css" media="all" rel="stylesheet" type="text/css" />
<script src="__ADMIN__/plugins/bootstrap-fileinput/js/fileinput.js" type="text/javascript"></script>
<script src="__ADMIN__/plugins/bootstrap-fileinput/js/locales/zh.js" type="text/javascript"></script>
~~~
注意:__ADMIN__路徑解析不一定正確
> 初始化
~~~
<script type="text/javascript" >
$('#file-zh').fileinput({
language: 'zh',
uploadUrl: '#',
allowedFileExtensions: ['jpg', 'png', 'gif'],
});
</script>
~~~
### 3、修改common.php
位置:\application\admin\common.php
~~~
function downfiles($fieldinfo){
//字段名
$field = $fieldinfo['field'];
$url = url('upload_downfiles');
//反序列化設置項
$setting = unserialize($fieldinfo['setting']);
$allowext = $setting['allowext']; //zip|rar
$maxnumber = $setting['maxnumber'];
//字符串格式調整
$allowext = str_replace("|","','",$allowext);
$allowext = "'" . $allowext . "'";
$str = <<<EOF
<input type="text" id="info_$field" name="info[$field]" class="input-large form-control">
<input id="file-zh" name="file[]" type="file" multiple>
<link href="__ADMIN__/plugins/bootstrap-fileinput/css/fileinput.css" media="all" rel="stylesheet" type="text/css" />
<script src="__ADMIN__/plugins/bootstrap-fileinput/js/fileinput.js" type="text/javascript"></script>
<script src="__ADMIN__/plugins/bootstrap-fileinput/js/locales/zh.js" type="text/javascript"></script>
<script type="text/javascript" >
$('#file-zh').fileinput({
language: 'zh',
uploadUrl: '$url',
allowedFileExtensions: [$allowext],
uploadAsync: true, //異步上傳
maxFileCount: $maxnumber
});
$('#file-zh').on("fileuploaded", function(event, data, previewId, index){
var images_value = $('#info_$field').val()=='' ? '' : $('#info_$field').val() + ',';
$('#info_$field').val( images_value + data.response);
$('#file-zh').val('');
});
</script>
EOF;
return $str;
}
~~~
### 4、修改控制器
位置:\application\admin\Content.php
~~~
//多文件上傳
public function upload_downfiles(){
$files = request()->file('file');
foreach ($files as $file) {
$info = $file->move(ROOT_PATH . 'public/uploads');
if($info) {
return json_encode($info->getSaveName());
}
}
}
~~~
## 三、完善Bootstrap fileinput插件功能
### (一)上傳亂碼-升級插件
#### 1、修改js
位置:static\admin\plugins\bootstrap-fileinput\js\fileinput.js
行數:
~~~
353:增加tRar
454:tRar = '<div class="kv-preview-data file-preview-other-frame">\n' + $h.DEFAULT_PREVIEW + '\n</div>\n';
496:rar: tRar,
499:allowedPreviewTypes: ['image', 'html', 'text', 'video', 'audio', 'flash', 'pdf', 'rar', 'object'],
510:rar: {width: "160px", height: "160px"},
522:rar: vDefaultDim,
551:rar: function (vType, vName) {
return $h.compare(vType, 'application/octet-stream', true) || $h.compare(vName, /\.(rar|zip)$/i);
},
3634:'rar': 'rar',
~~~
### (二)刪除功能
#### 1、自定義文件屬性
~~~
$('#'+previewId).attr('studyfox_img',data.response);
上傳文件函數
$('#file-zh').on("fileuploaded", function(event, data, previewId, index){
var images_value = $('#info_$field').val()=='' ? '' : $('#info_$field').val() + ',';
$('#info_$field').val( images_value + data.response);
$('#file-zh').val('');
//在當前圖片DIV里添加圖片地址
$('#'+previewId).attr('studyfox_img',data.response);
});
~~~
#### 2、回調函數
思路:與多圖上傳類似
~~~
$delete_url = url('delete_file');
//刪除文件
$('#file-zh').on("filesuccessremove", function(event, id){
var img_src = $('#'+id).attr('studyfox_img');
//后臺刪除文件
$.ajax({
url: '$delete_url',
type: 'POST',
data: {'img': img_src},
success: function(result, textStatus){
//圖片刪除成功后移除文本框圖片信息,三種情況 ,號位置在前 后 或沒有,號
var images_value = $('#info_$field').val();//隱藏文本框的值
images_value = images_value.replace(img_src+',', ''); //替換,號在右邊
images_value = images_value.replace(','+img_src, ''); //替換,號在左邊
images_value = images_value.replace(img_src, ''); //直接替換
//重新賦值
$('#info_$field').val(images_value);
},
error: function(XMLHttpRequest, textStatus){
layer.alert('刪除失敗!', {icon:2});
}
});
});
~~~
#### 3、控制器處理
~~~
//刪除文件或圖片
public function delete_file(){
$delete_url = input('img');
try {
unlink(ROOT_PATH . 'public/uploads/' . $delete_url); //刪除成功返回1
} catch (Exception $e) { }
}
~~~
- Layer無刷新不跳轉彈框提示信息
- 整合ThinkPHP+實用代碼
- TP整合Layer插件實現無刷新
- 自定義助手函數
- 添加信息失敗后不跳轉
- 三種無限級分類
- TP常用代碼
- 自定義公共函數
- TP模型管理專題
- TP模型管理之添加模型
- sfox_newmodel.sql
- TP模型管理之刪除模型
- TP模型管理之編輯模型
- TP模型管理之字段添加
- sfox_newmodel.sql_edit
- layer_hplus.js_edit
- TP模型管理之字段刪除
- TP模型管理之字段編輯
- TP模型管理之預覽模型
- TP模型管理之公共函數
- layer_hplus.js_修訂一
- TP模型管理之預覽模型靜態頁
- 后臺內容管理系統
- 分類樹顯示
- 內容列表顯示
- 信息發布
- 編輯信息
- layer_hplus.js
- myJs第一版
- myJs第二版
- myJs第三版
- myJs第四版
- TP5插件用法
- Datatables
- WebUploader
- bootstrap-fileinput
- UEditor
- 簡單調用
- 路徑問題
- 跨域多圖上傳
- 跨域單圖上傳
- UEditor圖片跨域上傳解決方案
- 定制工具欄圖標
- ajaxFileUpload
- LayUI
- 圖片上傳
- layui分頁
- 搜索頁
- 搜索優化及刪除
- Uploadify
- TP5前端應用
- 靜態首頁
- 前臺首頁功能實現
- 自定義標簽庫
- 前臺模板繼承應用
- 首頁自定義標簽改進
- 文章內容頁
- 自定義標簽改進
- 自定義標簽修正
- 圖片等比例自動縮放
- 后臺權限管理
- 角色管理
- 規則管理
- 權限設置
- 會員管理
- 權限管理
- 前臺登錄注冊功能
- 注冊登錄
- 阿里大于手機注冊
- 阿里大于升級阿里云短信服務
- 自動登錄完成
- PHP異位或加密實現自動登陸
- 微信開發
- 分享接口
- 靜態頁面實現微信分享
- 動態頁微信分享
- 頁面靜態化
- 1-全站靜態化前期配置
- 2-鏈接地址靜態化
- TP5常用片段代碼
- 加載靜態資源路徑與常量
- thinkphp5預定義常量
- 刪除某文件夾的內容
- 解壓插件包
- 異步提交插件
- 其他功能
- 背景音樂
- 手機訪問PC網站自動跳轉到手機網站代碼
- 手機微信音樂MP3播放器
- 后盾之網頁背景音樂
- 播放器寬度自適應
- 前臺首頁數據調用
- 視頻列表
- 搜索分頁
- H5解決蘋果(IOS)不能自動播放音樂
- 清空緩存
- 文件處理常識
- 刪除路徑下的所有文件夾和文件
- 一鍵清空緩存
- 評論留言
- 格式化時間
- 替換微博內容的URL地址@用戶與表情
- PHP正則理解
- jQuery評論插件
- TP空操作
- TP路由
- 跨域訪問
- 設置請其頭允許跨域請求
- 模板前臺判斷手機訪問跳轉手機網址代碼
- PHP遍歷一個文件夾下所有文件和子文件夾
- PHP獲取視頻的第一幀與時長
- TP5數據庫
- 鏈式操作原理
- update替換字段部分內容
- 后臺開發
- 后臺登錄頁居中顯示
- TP5自帶驗證碼
- JS & JQuery專題
- 二級城市聯動菜單
- 模板引擎
- 混合模板編譯
- 黃永成TP微博開發
- 消息推送
- memcache安裝
- 插件開發
- 插件介紹
- 插件鉤子
- 淺談初步理解鉤子
- 插件鉤子(hooks)分析
- 插件鉤子簡單理解
- 控制器調用插件
- 鉤子通用處理函數
- 插件基類代碼
- 插件測試代碼
- 淺談鉤子與插件
- 技術綜合
- 常用代碼
- PHP
- 56個PHP開發常用代碼片段(上)
- 56個PHP 開發常用代碼片段(中)
- 56個PHP 開發常用代碼片段(下)
- sublime text安裝自動補全注釋的插件
- 影音視頻開發
- 視頻
- H5視頻直播掃盲
- 音樂
- 語音
- PHP實現語音播報功能
- MUI
- 窗體操作