yii2组件之多图上传插件FileInput的详细使用,yii2fileinput
yii2组件之多图上传插件FileInput的详细使用,yii2fileinput
作者:白狼 出处:http://www.manks.top/yii2_multiply_images.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
文件上传也写过几篇文章了,包括最基本的yii2文件上传、异步上传到又拍云以及百度编辑器图片上传的问题,貌似不说点多图上传的就不完美。
今天介绍一款多图上传的插件 FileInput,至于为什么选中了TA作为我们上传的插件,一来这货跟Yii2有一腿,用起来方便;二来嘛,用这个插件不仅添加的时候好操作,修改的时候也可以直接通过异步的方式将图片悄无声息的删掉;最值得一提的是,界面效果融合了bootstrap,清爽简洁美观,看起来舒服。
借助一下场景,方便说明
假设我们有一张商品表,一张商品图片表,商品图片表只对商品id和图片地址进行存储
开始前准备工作
1、下载我们所需要的组件
composer <span>require</span> kartik-v/yii2-widget-fileinput "@dev"
2、准备一张商品表和一张商品图片表,商品图片表包括商品id和图片url即可
同步上传多图片操作
我们这里所谓的同步操作,即在添加商品时选择多张图片,然后跟随表单一同提交。来看看怎么使用的。
<span>use</span> kartik\<span>file</span><span>\FileInput; </span><span>//</span><span> 非ActiveForm的表单</span> <span>echo</span> '<label class="control-label">图片</label>'<span>; </span><span>echo</span> FileInput::<span>widget([ </span>'model' => <span>$model</span>, 'attribute' => 'banner[]', 'options' => ['multiple' => <span>true</span><span>] ]); </span><span>//</span><span>使用ActiveForm的表单</span> <span>echo</span> <span>$form</span>->field(<span>$model</span>, 'banner[]')->widget(FileInput::classname(),<span> [ </span>'options' => ['multiple' => <span>true</span>],<span> ]);</span>
若是要上传多图,记得选择图片的时候多选哦。
如此一来,图片选择好了直接提交表单就好,后端文件上传的程序需要自行处理,如果你还没有实现,可以参考文件上传的基本操作。需要提醒的是,以本文为例,此处我们给商品添加多图片实际是操作了两张数据表。
商品图的异步修改(包括删除\添加)操作
开篇可以看到,对于商品的banner图,我们是跟随表单一同提交而进行的上传,接着我们说一说这个麻烦事:编辑商品的时候如何展示商品图以及如何对商品图进行更新\新增\删除的操作?
首先,我们在controller中获取商品对应的banner图,在编辑商品页面展现banner图之前,我们对其稍微进行一下处理:
<span>//</span><span> 假设商品的banner图是 $relationBanners的集合, $id是商品的id // $relationBanners的数据结构如:</span><span> /*</span><span>* * Array *( * [0] => Array * ( * [id] => 1484314 * [goods_id] => 1173376 * [banner] => ./uploads/20160617/146612713857635322241f2.png * ) * *) </span><span>*/</span> <span>$relationBanners</span> = Banner::find()->where(['goods_id' => <span>$id</span>])->asArray()-><span>all(); </span><span>//</span><span> @param $p1 Array 需要预览的商品图,是商品图的一个集合 // @param $p2 Array 对应商品图的操作属性,我们这里包括商品图删除的地址和商品图的id</span> <span>$p1</span> = <span>$p2</span> =<span> []; </span><span>if</span> (<span>$relationBanners</span><span>) { </span><span>foreach</span> (<span>$relationBanners</span> <span>as</span> <span>$k</span> => <span>$v</span><span>) { </span><span>$p1</span>[<span>$k</span>] = <span>$v</span>['banner'<span>]; </span><span>$p2</span>[<span>$k</span>] =<span> [ </span><span>//</span><span> 要删除商品图的地址</span> 'url' => Url::toRoute('/banner/delete'), <span>//</span><span> 商品图对应的商品图id</span> 'key' => <span>$v</span>['id'],<span> ]; } } </span><span>return</span> <span>$this</span>->render('banner',<span> [ </span><span>//</span><span> other params</span> 'p1' => <span>$p1</span>, 'p2' => <span>$p2</span>, <span>//</span><span> 商品id</span> 'id' => <span>$id</span>,<span> ]);</span>
视图文件View的代码可参考
<span>//</span><span> 视图文件</span> <span>use</span> kartik\<span>file</span><span>\FileInput; </span><?<span>php </span><span>echo</span> <span>$form</span>->field(<span>$model</span>, 'banner[]')->label('banner图')->widget(FileInput::classname(),<span> [ </span>'options' => ['multiple' => <span>true</span>], 'pluginOptions' =><span> [ </span><span>//</span><span> 需要预览的文件格式</span> 'previewFileType' => 'image', <span>//</span><span> 预览的文件</span> 'initialPreview' => <span>$p1</span>, <span>//</span><span> 需要展示的图片设置,比如图片的宽度等</span> 'initialPreviewConfig' => <span>$p2</span>, <span>//</span><span> 是否展示预览图</span> 'initialPreviewAsData' => <span>true</span>, <span>//</span><span> 异步上传的接口地址设置</span> 'uploadUrl' => Url::toRoute(['/goods/async-banner']), <span>//</span><span> 异步上传需要携带的其他参数,比如商品id等</span> 'uploadExtraData' =><span> [ </span>'goods_id' => <span>$id</span>,<span> ]</span>, 'uploadAsync' => <span>true</span>, <span>//</span><span> 最少上传的文件个数限制</span> 'minFileCount' => 1, <span>//</span><span> 最多上传的文件个数限制</span> 'maxFileCount' => 10, <span>//</span><span> 是否显示移除按钮,指input上面的移除按钮,非具体图片上的移除按钮</span> 'showRemove' => <span>true</span>, <span>//</span><span> 是否显示上传按钮,指input上面的上传按钮,非具体图片上的上传按钮</span> 'showUpload' => <span>true</span>, <span>//</span><span>是否显示[选择]按钮,指input上面的[选择]按钮,非具体图片上的上传按钮</span> 'showBrowse' => <span>true</span>, <span>//</span><span> 展示图片区域是否可点击选择多文件</span> 'browseOnZoneClick' => <span>true</span>, <span>//</span><span> 如果要设置具体图片上的移除、上传和展示按钮,需要设置该选项</span> 'fileActionSettings' =><span> [ </span><span>//</span><span> 设置具体图片的查看属性为false,默认为true</span> 'showZoom' => <span>false</span>, <span>//</span><span> 设置具体图片的上传属性为true,默认为true</span> 'showUpload' => <span>true</span>, <span>//</span><span> 设置具体图片的移除属性为true,默认为true</span> 'showRemove' => <span>true</span>,<span> ]</span>,<span> ]</span>, <span>//</span><span> 一些事件行为</span> 'pluginEvents' =><span> [ </span><span>//</span><span> 上传成功后的回调方法,需要的可查看data后再做具体操作,一般不需要设置</span> "fileuploaded" => "<span>function (event, data, id, index) { console.log(data); }</span>",<span> ]</span>,<span> ]); </span>?>
如上所述,我们罗列了一些都是组件 FileInput的基本属性和设置,如有所需,可查看文档看属性的详细说明。
[考虑目前国内网站大部分采集文章十分频繁,更有甚者不注明原文出处,原作者更希望看客们查看原文,以防有任何问题不能更新所有文章,避免误导!]
查看原文

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

CrystalDiskMark是一款适用于硬盘的小型HDD基准测试工具,可以快速测量顺序和随机读/写速度。接下来就让小编为大家介绍一下CrystalDiskMark,以及crystaldiskmark如何使用吧~一、CrystalDiskMark介绍CrystalDiskMark是一款广泛使用的磁盘性能测试工具,用于评估机械硬盘和固态硬盘(SSD)的读写速度和随机I/O性能。它是一款免费的Windows应用程序,并提供用户友好的界面和各种测试模式来评估硬盘驱动器性能的不同方面,并被广泛用于硬件评

PyCharm是一款功能强大且受欢迎的Python集成开发环境(IDE),提供了丰富的功能和工具,使得开发者们可以更加高效地编写代码。而PyCharm的插件机制更是其功能扩展的利器,通过安装不同的插件,可以为PyCharm增加各种功能和定制化的特性。因此,对于PyCharm新手来说,了解并熟练安装插件是至关重要的。本文将为你详细介绍PyCharm插件安装的全

foobar2000是一款能随时收听音乐资源的软件,各种音乐无损音质带给你,增强版本的音乐播放器,让你得到更全更舒适的音乐体验,它的设计理念是将电脑端的高级音频播放器移植到手机上,提供更加便捷高效的音乐播放体验,界面设计简洁明了易于使用它采用了极简的设计风格,没有过多的装饰和繁琐的操作能够快速上手,同时还支持多种皮肤和主题,根据自己的喜好进行个性化设置,打造专属的音乐播放器支持多种音频格式的播放,它还支持音频增益功能根据自己的听力情况调整音量大小,避免过大的音量对听力造成损害。接下来就让小编为大

Chrome的插件扩展程序安装目录是什么?正常情况下,Chrome插件扩展程序的默认安装目录如下:1、windowsxp中chrome插件默认安装目录位置:C:\DocumentsandSettings\用户名\LocalSettings\ApplicationData\Google\Chrome\UserData\Default\Extensions2、windows7中chrome插件默认安装目录位置:C:\Users\用户名\AppData\Local\Google\Chrome\User

网易邮箱,作为中国网民广泛使用的一种电子邮箱,一直以来以其稳定、高效的服务赢得了用户的信赖。而网易邮箱大师,则是专为手机用户打造的邮箱软件,它极大地简化了邮件的收发流程,让我们的邮件处理变得更加便捷。那么网易邮箱大师该如何使用,具体又有哪些功能呢,下文中本站小编将为大家带来详细的内容介绍,希望能帮助到大家!首先,您可以在手机应用商店搜索并下载网易邮箱大师应用。在应用宝或百度手机助手中搜索“网易邮箱大师”,然后按照提示进行安装即可。下载安装完成后,我们打开网易邮箱账号并进行登录,登录界面如下图所示

在如今云存储已经成为我们日常生活和工作中不可或缺的一部分。百度网盘作为国内领先的云存储服务之一,凭借其强大的存储功能、高效的传输速度以及便捷的操作体验,赢得了广大用户的青睐。而且无论你是想要备份重要文件、分享资料,还是在线观看视频、听取音乐,百度网盘都能满足你的需求。但是很多用户们可能对百度网盘app的具体使用方法还不了解,那么这篇教程就将为大家详细介绍百度网盘app如何使用,还有疑惑的用户们就快来跟着本文详细了解一下吧!百度云网盘怎么用:一、安装首先,下载并安装百度云软件时,请选择自定义安装选

MetaMask(中文也叫小狐狸钱包)是一款免费的、广受好评的加密钱包软件。目前,BTCC已支持绑定MetaMask钱包,绑定后可使用MetaMask钱包进行快速登入,储值、买币等,且首次绑定还可获得20USDT体验金。在BTCCMetaMask钱包教学中,我们将详细介绍如何注册和使用MetaMask,以及如何在BTCC绑定并使用小狐狸钱包。MetaMask钱包是什么?MetaMask小狐狸钱包拥有超过3,000万用户,是当今最受欢迎的加密货币钱包之一。它可免费使用,可作为扩充功能安装在网络

用户使用Edge浏览器的过程中可能会添加一些插件来满足自己更多的使用需求。但是在添加插件时显示不支持此插件,这该如何解决?今日小编就来给大家分享三种解决办法,快来试试吧。 方法一:尝试用其他的浏览器。 方法二:浏览器上的FlashPlayer可能过时或者丢失,导致此插件不受支持状态,可在官网下载最新版本。 方法三:同时按下“Ctrl+Shift+Delete”键。 点击“清除数据”,重新打开浏览器即可。
