php - wap端里面的图片上传是怎么做的,如图

查看:107
本文介绍了php - wap端里面的图片上传是怎么做的,如图的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

wap端里面的图片上传是怎么做的
点添加,读取手机的图片,确定后返回添加界面,可以继续添加图片
类似下图:

懂的朋友欢迎指导我下
备注:我框架是yii2.0的,如果有yii的插件更好好

解决方案

这个在下还是有点经验的。

上传按钮不一致的问题

首先从上传的按钮说起,默认 <input type="file">效果丑爆了,而且不同操作系统,不同浏览器不一样,关于上传按钮的美化网上一大堆。大体思路:

<div class="container">
    <input type="file">
    <div class="upload"></div>
</div>

inputupload 相对于contianer 定位,将 input z-index 叠放在 .upload的上,同时将其 opcity = 0; 这样需要什么效果直接操作 .upload的就行。比如你放一个图片按钮、字体图标的加号等等......

文件 Ajax上传

本身浏览器 Ajax 不支持直接上传二进制文件,也就是传统方式必须使用 from表单 post 实现。但是html5 新增了文件api,让Ajax文件上传成为一件轻松的事情。具体实现

http://www.html5rocks.com/zh/tutorials/file/xhr2/

上面这边文章有讲到,讲的非常好自己看看问题不大,或者自行百度、谷歌 html5 Ajax 文件上传 File API

上传到服务器

文件到服务器以后假设返回 abc.png,这时候你前端 js ajxa 把图片动态写到页面上。


$.ajax({
    type : 'post',
    url  : 'server/upload',
    data : {data: 'fromData'},
    success : function(data) {
        // 这里假设返回的 data = 'abc.png'
        $('ul').append('<li><img src'"+data+'" /></li>');
    }
})

补充:多图片问题

如果上传的是多图片,对于前端来说,input多加一个multiple属性即可

<input type="file" multiple="multiple" name="file[]">

至于想限制个数,当用户change事件完成以后判断文件个数可以解决。服务器端处理完以后返回图片信息的json格式,例如:

["upload/1.png", "upload/2.png", "upload/3.png"]

前端将json转为JavaScript对象,然后将其追加到页面上即可。其实最大的问题在于html5文件api的使用,这个掌握了就很好处理。

之前写的,可能不完善,你可以参考参考

http://www.cnblogs.com/chenshuo/p/3895745.html

微信JSSDK的使用

如果是基于微信开发,建议采用微信的JSSDK实现文件的上传,用户体验非常的好,自己做的上传除非你服务器配置吊,带宽土豪级别,否则自己的上传还是有问题的。如果坚持用自己的,也可以专门来一个上传服务器(文件存储服务器)这样可以在文件上传大量占用带宽时不影响其他业务。

实现:

  1. 首先你的详细的看看微信的JSSDK关于上传这块的东西,自己探索下问题不大;

  2. 我主要想说的是在实际开发中,微信JSSDK文件上传默认是单一文件上传,寻觅好久找到了方法,可能你会用到,贴出来

微信图片上传接口多图像上传(递归上传)http://www.cnblogs.com/chenshuo/p/4838592.html

这篇关于php - wap端里面的图片上传是怎么做的,如图的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆