如何判断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行的代码

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


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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存