资讯专栏INFORMATION COLUMN

TP5整合阿里云OSS上传文件第二节,异步上传头像实现,

dayday_up / 1890人阅读

摘要:版本也是我最喜欢的方式这个代码有点黏在一起了凑合看把李昊天创建实例服务器异步接受地址指定选择文件的按钮容器禁止多选不压缩选择之后自动上传防止低版本浏览器用到了只允许选择图片文件。

TP5整合阿里云OSS上传文件第二节,上传头像实现
首先先看一个效果图
上传失败效果图:

上传成功效果图:

使用的插件以及UI库:
webuploader
bootstrap
jquery
自己扩展了几个样式 大家修改样式很简单,相信各位都没什么可说的!
也在压缩包里面,大家可以参考一下!

代码里面全部都有很明确的注释,
这次实现的只有前端逻辑以及上传到阿里云服务器,并没有修改数据库,由于天色已晚,剩下的就有时间再写把!
首先去下载webuploader插件 地址传送门:https://github.com/fex-team/w...
下载之后我们根据自己需要选择,本次代码中使用的是完整版压缩版本的!

由于页面太单挑的话会很难看 所以自己写了样式 up.css来让页面稍微好看点(没考虑页面兼容性,反正在我电脑是正常的 (^▽^))
有header 头部 footer 底部 nav.menu侧边栏导航以及main内容区域

将之前的up.html改成如下结构;




    
    
    
    {{css href="/static/css/webuploader.red.css,https://cdn.bootcss.com/bootstrap/3.0.0/css/bootstrap.css,/static/css/up.css"}}
    Document


选择文件
{{js href="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js,/static/js/webuploader.min.js,/static/js/upload.js"}}

里面有几个文件说一下
bootstrap.css 不用说大家都知道的,我用的是cdn 没有下载到本地;
webuploader.red.css 是上传按钮美化的样式,(里面代码不多) 这个是我修改之后的 原来的按钮的蓝色的 我并不太喜欢 喜欢这种红色! 修改的还有一个黑色,默认的也在压缩包里面!
up.css 主要就是页面的样式和提示框,进度条 之类的样式

jquery.min.js 不用说大家也都知道的,用的是cdn 没有下载到本地;
webuploader.min.js 组件核心文件 里面代码超级多
upload.js 上传的前端逻辑代码 也是核心代码

这里只说一下 upload.js 代码 其他的没什么说的,
版本1:

/**
 * User: 李昊天
 * Date: 2018/5/18
 * Time: 1:15
 * Email: haotian0607@gmail.com
 */
$(function () {
    var $face = $("#face"), thumbnailWidth = 100, thumbnailHeight = 100;
    //创建uploader实例
    var uploader = WebUploader.create({
        server: uploaderUrl, //服务器异步接受地址!
        pick: {
            id: "#changeFile", //指定选择文件的按钮容器
            multiple: false, //禁止多选
        },
        resize: false, //不压缩image
        auto: true, //选择之后自动上传
        swf: "../flash/Uploader.swf", //防止低版本浏览器 用到了flash
        // 只允许选择图片文件。
        accept: {
            title: "Images",
            extensions: "gif,jpg,jpeg,bmp,png",
            mimeTypes: "image/*"
        }
    });
    // 当有文件添加进来的时候
    uploader.on("fileQueued", function (file) {
        var $img = $face.find("img"); //获取到头像的DOM
        // 创建缩略图
        uploader.makeThumb(file, function (error, src) {
            if (error) {
                $img.replaceWith("不能预览");
                return;
            }
            $img.attr("src", src);
        }, thumbnailWidth, thumbnailHeight);
    });
    // 文件上传过程中创建进度条实时显示。
    uploader.on("uploadProgress", function (file, percentage) {
        $percent = $face.find(".progress .progress-bar");
        // 避免重复创建
        if (!$percent.length) {
            //构建进度条DOM
            $face.append("
"); //这个是提示框 $percent = $("
").appendTo($face).find("progress-bar"); } $percent.css({"width": 50 + "%"}); //让进度条动起来 }); // 文件上传成功,给dialog添加class, 用样式标记上传成功。 uploader.on("uploadSuccess", function (file) { //找到头像DIV下面的dialog 添加一个success的样式类将内容改变成上传成功并且显示! $face.find(".dialog").addClass("success").text("上传成功").show(); }); // 文件上传失败,同样是添加Class uploader.on("uploadError", function (file) { //找到头像DIV下面的dialog 添加一个error的样式类将内容改变成上传失败并且显示! $face.find(".dialog").addClass("error").text("上传失败").show(); }); // 完成上传完了,成功或者失败,先删除进度条。 uploader.on("uploadComplete", function (file) { $face.find(".progress").remove(); }); });

版本2:也是我最喜欢的方式,这个代码有点黏在一起了,凑合看把!

/**
 * User: 李昊天
 * Date: 2018/5/18
 * Time: 1:15
 * Email: haotian0607@gmail.com
 */
$(function () {
    var $face = $("#face"), thumbnailWidth = 100, thumbnailHeight = 100;
    //创建uploader实例
    WebUploader.create({
        server: uploaderUrl, //服务器异步接受地址!
        pick: {
            id: "#changeFile", //指定选择文件的按钮容器
            multiple: false, //禁止多选
        },
        resize: false, //不压缩image
        auto: true, //选择之后自动上传
        swf: "../flash/Uploader.swf", //防止低版本浏览器 用到了flash
        // 只允许选择图片文件。
        accept: {
            title: "Images",
            extensions: "gif,jpg,jpeg,bmp,png",
            mimeTypes: "image/*"
        }
    }).on("fileQueued", function (file) {
        // 当有文件添加进来的时候
        var $img = $face.find("img"); //获取到头像的DOM
        // 创建缩略图
        this.makeThumb(file, function (error, src) {
            if (error) {
                $img.replaceWith("不能预览");
                return;
            }
            $img.attr("src", src);
        }, thumbnailWidth, thumbnailHeight);
    }).on("uploadProgress", function (file, percentage) {
        // 文件上传过程中创建进度条实时显示。
        $percent = $face.find(".progress .progress-bar");
        // 避免重复创建
        if (!$percent.length) {
            //构建进度条DOM
            $face.append("
"); //这个是提示框 $percent = $("
").appendTo($face).find("progress-bar"); } $percent.css({"width": 50 + "%"}); //让进度条动起来 }).on("uploadSuccess", function (file) { // 文件上传成功,给dialog添加class, 用样式标记上传成功。 //找到头像DIV下面的dialog 添加一个success的样式类将内容改变成上传成功并且显示! $face.find(".dialog").addClass("success").text("上传成功").show(); }).on("uploadError", function (file) { // 文件上传失败,同样是添加Class //找到头像DIV下面的dialog 添加一个error的样式类将内容改变成上传失败并且显示! $face.find(".dialog").addClass("error").text("上传失败").show(); }).on("uploadComplete", function (file) { // 完成上传完了,成功或者失败,先删除进度条。 $face.find(".progress").remove(); }); });

最后给大家看看扩展的样式:
默认的

红色:颜色值:#E4393c;

黑色:颜色值:#222222;

页面中没有使用字体图标,只有在扩展样式里面我加了svg背景,使用的是伪元素,

.webuploader-pick:before{
    content:"";
    display: inline-block;
    width:20px;
    height: 20px;
    background: url("../img/upload-1.svg");
    z-index: 999;
    background-size: 100% 100%;
    position: relative;
    top:4px;
}

对于新手朋友:
拿到代码之后创建一个控制器
渲染视图,视图中将up.html复制进去;
然后将静态资源文件放到public/static/文件夹下

如果不写使用bs库的朋友可以用下面的代码代替进度条
css:

.progress {
 height: 20px;
 margin-bottom: 20px;
 overflow: hidden;
 background-color: #f5f5f5;
 border-radius: 4px;
 -webkit-box-shadow: inset 0 1px 2px rgba(0, 0, 0, .1);
 box-shadow: inset 0 1px 2px rgba(0, 0, 0, .1);
}
.progress-bar {
 float: left;
 width: 0;
 height: 100%;
 font-size: 12px;
 line-height: 20px;
 color: #fff;
 text-align: center;
 background-color: #428bca;
 -webkit-box-shadow: inset 0 -1px 0 rgba(0, 0, 0, .15);
 box-shadow: inset 0 -1px 0 rgba(0, 0, 0, .15);
 -webkit-transition: width .6s ease;
 transition: width .6s ease;
}
.progress-bar-success {
 background-color: #5cb85c;
}
/*bootstrap.css文件第4555行~第4557行*/
.progress-bar-info {
 background-color: #5bc0de;
}
/*bootstrap.css文件第4562行~第4564行*/
.progress-bar-warning {
 background-color: #f0ad4e;
}
/*bootstrap.css文件第4569行~第4571行*/
.progress-bar-danger {
 background-color: #d9534f;
}

html:

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/30783.html

相关文章

  • TP5整合阿里OSS上传文件二节,异步上传头像(下)

    摘要:找到头像下面的添加一个的样式类将内容改变成上传成功并且显示上传成功文件上传失败,同样是添加找到头像下面的添加一个的样式类将内容改变成上传失败并且显示上传失败完成上传完了,成功或者失败,先删除进度条。 是这个功能的最后一步了,新增插件:layer.js 弹窗层组件jquery.form 异步表单提交插件 新增CSS:layer扩展文件 修改layer弹窗的皮肤,默认的不喜欢!基本代码和之...

    qiangdada 评论0 收藏0
  • TP5整合阿里OSS上传文件二节,异步上传头像(下)

    摘要:找到头像下面的添加一个的样式类将内容改变成上传成功并且显示上传成功文件上传失败,同样是添加找到头像下面的添加一个的样式类将内容改变成上传失败并且显示上传失败完成上传完了,成功或者失败,先删除进度条。 是这个功能的最后一步了,新增插件:layer.js 弹窗层组件jquery.form 异步表单提交插件 新增CSS:layer扩展文件 修改layer弹窗的皮肤,默认的不喜欢!基本代码和之...

    dmlllll 评论0 收藏0
  • TP5整合阿里OSS上传文件二节,异步上传头像(下)

    摘要:找到头像下面的添加一个的样式类将内容改变成上传成功并且显示上传成功文件上传失败,同样是添加找到头像下面的添加一个的样式类将内容改变成上传失败并且显示上传失败完成上传完了,成功或者失败,先删除进度条。 是这个功能的最后一步了,新增插件:layer.js 弹窗层组件jquery.form 异步表单提交插件 新增CSS:layer扩展文件 修改layer弹窗的皮肤,默认的不喜欢!基本代码和之...

    draveness 评论0 收藏0
  • TP5整合阿里OSS上传文件二节,异步上传头像(下)

    摘要:找到头像下面的添加一个的样式类将内容改变成上传成功并且显示上传成功文件上传失败,同样是添加找到头像下面的添加一个的样式类将内容改变成上传失败并且显示上传失败完成上传完了,成功或者失败,先删除进度条。 是这个功能的最后一步了,新增插件:layer.js 弹窗层组件jquery.form 异步表单提交插件 新增CSS:layer扩展文件 修改layer弹窗的皮肤,默认的不喜欢!基本代码和之...

    Dongjie_Liu 评论0 收藏0
  • TP5整合阿里OSS上传文件二节,异步上传头像实现,

    摘要:版本也是我最喜欢的方式这个代码有点黏在一起了凑合看把李昊天创建实例服务器异步接受地址指定选择文件的按钮容器禁止多选不压缩选择之后自动上传防止低版本浏览器用到了只允许选择图片文件。 TP5整合阿里云OSS上传文件第二节,上传头像实现首先先看一个效果图上传失败效果图:showImg(https://segmentfault.com/img/bVbaJLZ?w=983&h=561);上传成功...

    douzifly 评论0 收藏0

发表评论

0条评论

dayday_up

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<