如何判断uploadify插件是否选择了文件

如何判断uploadify插件是否选择了文件,第1张

这里要说的问题是为了验证上传文件是否已经存在于服务器,就需要checkExisting这一选项,看页面JS代码如下:

'checkExisting' : '/static/js/plugins/uploadify/check-exists.php',

会交给check-exists.PHP后台文件来处理判断文件存不存在,最初的源文件是这样的:

就这么几句话,按常理来说,有了路径文件名是可以file_exists()判断文件是否存在服务器,但忽略了一个问题,就是如果自定义了上传文件存放的路径,如上所看到的floder:

若是这样的话,文件判断那就肯定是不存在的了,因为路径都不对了,肯定找不到该文件……,此时看到,既然文件名能够$_POST[]过来,那希望这个folder也能POST过来,那就来打印看看到底$_POST里面放了些什么,结果有些失望:

array (size=1)

'filename' =>string 'OOOPIC_SHIJUNHONG_20090809ad6104071d324dda.jpg' (length=46)

就只有filename,什么都没了,接着还是不甘心,对JS不咋样的还是硬着头皮去看jquery.uploadify.min.js的源码,皇天不负有心人!找了好久终于找到了,相关代码如下:

原来这是已ajax提交过来的,其中的数据就只有filename,于是就想到把floder也传过去,修改:

data: {

filename: d.name,

floder: e.formData.folder

},

然后再在check-exists.php文件接收:

这样就大功告成了,可以判断文件是否存在了。

如下图:

可以间接的判断已选择文件的总数来判断是否选择了文件。

即用方法$("#uploadmediaSrcfile").data('uploadify').queueData.queueLength

获取到uploadify组件中选择的文件总数,如果返回的值大于0,则表示选择了文件,

反之则没有选择文件。

其中:

1、uploadmediaSrcfile是类型为file的input标签的id值;

2、date('uploadify')中的uploadify为固定值

3、此方法在版本为Uploadify v3.2.1中是测试通过的。

具体可以参考jquery.uploadify.js源文件中的第312行和319行的代码

(它自己也是通过这种方式获取选择文件总数的)。

onSelect

当选中一个文件后触发此事件,默认会创建一个6位的随机编号的元素,并加入到文件队列中,如果返回false则不会执行此动作。

此事件有三个参数:

event: javascript的event对象

queueID: 选中文件的编号

fileObj: 一个包含文件详细信息的对象。

name – 文件名称

size – 文件的大小(字节)

creationDate – 文件的创建时间

modificationDate – 文件的修改时间

type – 文件的扩展名(包括'.')

所以说你想得到客户端的路径这样是不行的!


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11528220.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-16
下一篇 2023-05-16

发表评论

登录后才能评论

评论列表(0条)

保存