jquery实现图片上传前本地预览功能


Posted in Javascript onMay 10, 2016

本文实例为大家分享了jquery实现图片上传前预览的具体代码,供大家参考,具体内容如下
介绍之前有一个小问题,一直找不到图片预览时,图片不出来的原因,原来在于图片的路径!!!一直写的是图片的本地路径,没有什么用。直接上代码。

html部分:

<img id="pic" src="" >

<input id="upload" name="file" accept="image/*" type="file" style="display: none"/>

input:file事件是上传类型
较常用的属性值如下:
accept:表示可以选择的文件MIME类型,多个MIME类型用英文逗号分开,常用的MIME类型见下表。
若要支持所有图片格式,则写 * 即可。
multiple:是否可以选择多个文件,多个文件时其value值为第一个文件的虚拟路径

input:file的样式是不变的,所以若要改变它的样式,首先将它隐藏。display:none;

CSS部分:
因为做的是一个圆形的头像,所以对图片样式先进行定义。

#pic{
 width:100px;
 height:100px;
 border-radius:50% ;
 margin:20px auto;
 cursor: pointer;
 }

jQuery部分:

$(function() {
 $("#pic").click(function () {
 $("#upload").click(); //隐藏了input:file样式后,点击头像就可以本地上传
 $("#upload").on("change",function(){
 var objUrl = getObjectURL(this.files[0]) ; //获取图片的路径,该路径不是图片在本地的路径
 if (objUrl) {
 $("#pic").attr("src", objUrl) ; //将图片路径存入src中,显示出图片
 }
 });
 });
 });

 //建立一??可存取到?file的url
 function getObjectURL(file) {
 var url = null ;
 if (window.createObjectURL!=undefined) { // basic
 url = window.createObjectURL(file) ;
 } else if (window.URL!=undefined) { // mozilla(firefox)
 url = window.URL.createObjectURL(file) ;
 } else if (window.webkitURL!=undefined) { // webkit or chrome
 url = window.webkitURL.createObjectURL(file) ;
 }
 return url ;
 }

运行结果如下:

jquery实现图片上传前本地预览功能

更多精彩内容,请点击《jQuery上传操作汇总》,《ajax上传技术汇总》进行深入学习和研究。

以上就是本文的全部内容,希望对大家学习jquery程序有所帮助。

Javascript 相关文章推荐
js 对象是否存在判断
Jul 15 Javascript
ExtJS4 组件化编程,动态加载,面向对象,Direct
May 12 Javascript
随鼠标上下滚动的jquery代码
Dec 05 Javascript
JavaScript中的操作符==与===介绍
Dec 31 Javascript
javascript 动态创建表格的2种方法总结
Mar 04 Javascript
AngularJS模块详解及示例代码
Aug 17 Javascript
JavaScript实现HTML5游戏断线自动重连的方法
Sep 18 Javascript
使用webpack打包koa2 框架app
Feb 02 Javascript
详解Webpack-dev-server的proxy用法
Sep 08 Javascript
vue无限轮播插件代码实例
May 10 Javascript
在vue-cli中引入lodash.js并使用详解
Nov 13 Javascript
详解如何使用Node.js实现热重载页面
May 06 Javascript
基于JQuery的$.ajax方法进行异步请求导致页面闪烁的解决办法
May 10 #Javascript
基于jquery实现三级下拉菜单
May 10 #Javascript
jQuery Dialog对话框事件用法实例分析
May 10 #Javascript
bootstrap网页框架的使用方法
May 10 #Javascript
浅析Bootstrip的select控件绑定数据的问题
May 10 #Javascript
jQuery的文档处理程序详解
May 10 #Javascript
有关easyui-layout中的收缩层无法显示标题的解决办法
May 10 #Javascript
You might like
十天学会php(3)
2006/10/09 PHP
php 全局变量范围分析
2009/08/07 PHP
PHP取得一个类的属性和方法的实现代码
2011/05/22 PHP
php中批量修改文件后缀名的函数代码
2011/10/23 PHP
Laravel自动生成UUID,从建表到使用详解
2019/10/24 PHP
如何利用PHP实现上传图片功能详解
2020/09/24 PHP
javascript基础知识大集锦(二) 推荐收藏
2011/01/13 Javascript
setInterval与clearInterval的使用示例代码
2014/01/28 Javascript
使用GruntJS构建Web程序之合并压缩篇
2014/06/06 Javascript
简介JavaScript中search()方法的使用
2015/06/06 Javascript
浅析js绑定事件的常用方法
2016/05/15 Javascript
基于bootstrap风格的弹框插件
2016/12/28 Javascript
JS变量及其作用域
2017/03/29 Javascript
bootstrapvalidator之API学习教程
2017/06/29 Javascript
JS获取填报扩展单元格控件的值的解决办法
2017/07/14 Javascript
webpack使用 babel-loader 转换 ES6代码示例
2017/08/21 Javascript
用 Vue.js 递归组件实现可折叠的树形菜单(demo)
2017/12/25 Javascript
vue里的data要用return返回的原因浅析
2019/05/28 Javascript
Node.js实现简单管理系统
2019/09/23 Javascript
vue 保留两位小数 不能直接用toFixed(2) 的解决
2020/08/07 Javascript
python selenium UI自动化解决验证码的4种方法
2018/01/05 Python
Python查找第n个子串的技巧分享
2018/06/27 Python
Python列表推导式与生成器用法分析
2018/08/02 Python
python 计算方位角实例(根据两点的坐标计算)
2020/01/17 Python
解决python使用list()时总是报错的问题
2020/05/05 Python
python实现画图工具
2020/08/27 Python
英国一家专门出售品牌鞋子的网站:Allsole
2016/08/07 全球购物
联想加拿大官方网站:Lenovo Canada
2018/04/05 全球购物
机械制造毕业生求职信
2014/03/03 职场文书
小学生优秀评语
2014/12/29 职场文书
工程项目经理岗位职责
2015/02/02 职场文书
大雁塔导游词
2015/02/04 职场文书
圣贤教育改变命运观后感
2015/06/16 职场文书
大学生十八大感想
2015/08/11 职场文书
竞聘开场白方式有哪些?
2019/08/28 职场文书
Redis唯一ID生成器的实现
2022/07/07 Redis