先上一张图片给大家看看效果,有需要就下载学习。不一定非要在ThinkPHP里,只是我非常喜欢去用ThinkPHP做开发了。
好了。现在咱们需要的东西是,下载一个swfupload.js网上很多,自己百度吧.之前有人加我QQ说我写的博文大部分都是代码,看不懂,我以后写博文也先说明思路,然后开始贴代码分享
整个多图上传的流程
1.写好html代码,包括上传以后显示的效果的html,以及加载swfupload组件.和flash
2.在添加图片以后上传到php里处理上传并且返回上传图片的地址,加载到预览区域里.
3.点击X以后,ajax调用php的方法去删除预览区域的图片.
4.在添加图片和删除预览区域的图片的同时,都会更改一个隐藏域的值,这样在完成整个上传提交表单以后可以把图片的地址保存到数据库.(看需要)
好了。先写html代码吧。(css文件我就不贴了)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<
html
xmlns
=
"http://www.w3.org/1999/xhtml"
>
<
head
>
<
meta
http-equiv
=
"Content-Type"
content
=
"text/html; charset=utf-8"
/>
<
meta
http-equiv
=
"Cache-control"
content
=
"private, must-revalidate"
/>
<
title
>flash无刷新多图片上传</
title
>
<
script
type
=
"text/javascript"
>
var path='__STYLE__';
var url='__URL__';
</
script
>
<
script
type
=
"text/javascript"
src
=
"__STYLE__/js/jquery.js"
></
script
>
<
script
type
=
"text/javascript"
src
=
"__STYLE__/js/swfupload.js"
></
script
>
<
script
type
=
"text/javascript"
src
=
"__STYLE__/js/handlers.js"
></
script
>
<
link
href
=
"__STYLE__/css/default.css"
rel
=
"stylesheet"
type
=
"text/css"
/>
<
script
type
=
"text/javascript"
>
var swfu;
window.onload = function () {
swfu = new SWFUpload({
upload_url: "__URL__/uploadImg",
post_params: {"PHPSESSID": "<?
php
echo session_id();?>"},
file_size_limit : "2 MB",
file_types : "*.jpg;*.png;*.gif;*.bmp",
file_types_description : "JPG Images",
file_upload_limit : "100",
file_queue_error_handler : fileQueueError,
file_dialog_complete_handler : fileDialogComplete,
upload_progress_handler : uploadProgress,
upload_error_handler : uploadError,
upload_success_handler : uploadSuccess,
upload_complete_handler : uploadComplete,
button_image_url : "__STYLE__/images/upload.png",
button_placeholder_id : "spanButtonPlaceholder",
button_width: 113,
button_height: 33,
button_text : '',
button_text_style : '.spanButtonPlaceholder { font-family: Helvetica, Arial, sans-serif; font-size: 14pt;} ',
button_text_top_padding: 0,
button_text_left_padding: 0,
button_window_mode: SWFUpload.WINDOW_MODE.TRANSPARENT,
button_cursor: SWFUpload.CURSOR.HAND,
flash_url : "__STYLE__/swf/swfupload.swf",
custom_settings : {
upload_target : "divFileProgressContainer"
},
debug: false
});
};
</
script
>
</
head
>
<
body
>
<
form
action
=
"__URL__/s"
method
=
"post"
>
<
div
style
=
"width: 610px; height: auto; border: 1px solid #e1e1e1; font-size: 12px; padding: 10px;"
>
<
span
id
=
"spanButtonPlaceholder"
></
span
>
<
div
id
=
"divFileProgressContainer"
></
div
>
<
div
id
=
"thumbnails"
>
<
ul
id
=
"pic_list"
style
=
"margin: 5px;"
></
ul
>
<
div
style
=
"clear: both;"
></
div
>
</
div
>
</
div
>
<
input
type
=
"hidden"
name
=
"s"
id
=
""
value
=
""
/>
<
input
type
=
"submit"
value
=
"提交"
/>
</
form
>
</
body
>
</
html
>
|
详细说一下swfupload的配置项
upload_url 是上传图片处理的php地址
file_size_limit 上传大小限制
file_upload_limit 限制用户一次性最多上传多少张图片,0为不限制
file_queue_error_handler
file_dialog_complete_handler 添加文件上传选择框关闭以后执行的方法
upload_error_handler 文件上传错误的时候执行的方法
upload_success_handler 文件上传成功以后执行的方法
upload_complete_handler 文件上传完成以后执行的方法
debug: false 想研究swfupload的可以把这个设置为true,调试模式
接下来就是上传图片的php代码,我就用的TP的上传类,简单,容易懂
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
function
uploadImg() {
import(
'ORG.Net.UploadFile'
);
$upload
=
new
UploadFile();
// 实例化上传类
$upload
->maxSize = 3145728 ;
// 设置附件上传大小
$upload
->allowExts =
array
(
'jpg'
,
'gif'
,
'png'
,
'jpeg'
);
// 设置附件上传类型
$savepath
=
'./uploads/'
.
date
(
'Ymd'
).
'/'
;
if
(!
file_exists
(
$savepath
)){
mkdir
(
$savepath
);
}
$upload
->savePath =
$savepath
;
// 设置附件上传目录
if
(!
$upload
->upload()) {
// 上传错误提示错误信息
$this
->error(
$upload
->getErrorMsg());
}
else
{
// 上传成功 获取上传文件信息
$info
=
$upload
->getUploadFileInfo();
}
print_r(J(__ROOT__.
'/'
.
$info
[0][
'savepath'
].
'/'
.
$info
[0][
'savename'
]));
}
|
上传成功以后,echo或者print_r输出地址,因为他用的是ajax的方式。
预览区域设置的代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
function
uploadSuccess(file, serverData){
addImage(serverData);
var
$svalue=$(
'form>input[name=s]'
).val();
if
($svalue==
''
){
$(
'form>input[name=s]'
).val(serverData);
}
else
{
$(
'form>input[name=s]'
).val($svalue+
"|"
+serverData);
}
}
function
addImage(src){
var
newElement =
"<li><img class='content' src='"
+ src +
"' style=\"width:100px;height:100px;\"><img class='button' src="
+window.path+
"/images/fancy_close.png></li>"
;
$(
"#pic_list"
).append(newElement);
$(
"img.button"
).last().bind(
"click"
, del);
}
|
serverData就是在php里返回的图片地址,在返回以后,直接调用addImage方法,将地址加载到一个ul里。同时更新隐藏域里的值
删除图片设置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
var
del =
function
(){
// var fid = $(this).parent().prevAll().length + 1;
var
src=$(
this
).siblings(
'img'
).attr(
'src'
);
var
$svalue=$(
'form>input[name=s]'
).val();
$.ajax({
type:
"GET"
,
//访问WebService使用Post方式请求
url: window.url+
"/del"
,
//调用WebService的地址和方法名称组合---WsURL/方法名
data:
"src="
+ src,
success:
function
(data){
var
$val=$svalue.replace(data,
''
);
$(
'form>input[name=s]'
).val($val);
}
});
$(
this
).parent().remove();
}
|
ajax方式,提交到php方式,成功则更新隐藏域里的val,并且销毁元素。
1
2
3
4
5
6
7
8
|
function
del() {
$src
=
str_replace
(__ROOT__.
'/'
,
''
,
str_replace
(
'//'
,
'/'
,
$_GET
[
'src'
]));
if
(
file_exists
(
$src
)){
unlink(
$src
);
}
print_r(
$_GET
[
'src'
]);
exit
();
}
|
删除的方法很简单,就是删除ajax提交过来的地址的文件,并且返回删除的地址,ajax会处理并且自动更新隐藏域的val
整个ThinkPHP+swfupload上传图片的方法就完了。很简单。 ThinkPHP+swfupload多图上传实例下载链接: http://pan.baidu.com/s/1dD8avap 密码: 7idq