html页面选择图片上传时实现图片预览功能
2024-08-30 11:16:55
实现效果如下图所示
只需要将下面的html部分的代码放入你的代码即可
(注意引入jQuery文件和html头部的css样式,使用的是ajax提交)
<!--
需引入jQuery
引入样式文件
引入上传图片预览的代码
获取上传的图片信息
在php页面通过 request()->file() 获取图片信息
-->
<!-- 上传图片预览时需要的css start 无需改动-->
<style type="text/css">
.file {
position: relative;
display: inline-block;
background: #D0EEFF;
border: 1px solid #99D3F5;
border-radius: 4px;
padding: 4px 12px;
overflow: hidden;
color: #1E88C7;
text-decoration: none;
text-indent: 0;
line-height: 20px;
} .file input {
position: absolute;
font-size: 100px;
right: 0;
top: 0;
opacity: 0;
} .file:hover {
background: #AADFFD;
border-color: #78C3F3;
color: #004974;
text-decoration: none;
}
</style>
<!-- 上传图片预览时需要的css end --> <body> <div class="wrapper">
<div class="container-fluid"> <!-- end page title --> <div class="row">
<div class="col-12">
<div class="card">
<div class="card-body">
<form class="form-horizontal">
<div class="form-group row">
<label class="col-sm-2 col-form-label">实现图片预览效果</label>
<div class="col-sm-10">
<a href="javascript:;" class="file">选择文件
<input type="file" name="img" required>
</a>
<img id="img" height="100" src="">
</div>
</div>
<div class="form-group row">
<label class="col-sm-2 col-form-label"></label>
<div class="col-sm-10">
<button type="button" class="btn btn-primary" onclick="return preserve()">保存</button>
</div>
</div>
</form> </div> <!-- end card-box -->
</div> <!-- end card-->
</div><!-- end col -->
</div>
<!-- end row --> </div>
</div>
</body>
</html>
<script>
function preserve()
{
var formData = new FormData();
var img = $("[name='img']").prop('files')[0];/*获取上传图片的信息*/
formData.append("img",img);
$.ajax({
type : "post",
url : "{:URL('admin/Banner/shopbanneradd')}",/*此处填写上传路径*/
processData : false,
contentType : false,
data : formData,
success : function(data) { }
});
} </script>
<!-- 上传图片并预览的js文件 start 无需改动-->
<script type="text/javascript">
var small_img = document.querySelector('input[name=small_img]');
var img = document.querySelector('input[name=img]');
small_imgs = document.querySelector('#small_img');
imgs = document.querySelector('#img');
if (small_img) {
small_img.addEventListener('change', function() {
var file = this.files[0];
var reader = new FileReader();
// 监听reader对象的的onload事件,当图片加载完成时,把base64编码賦值给预览图片
reader.addEventListener("load", function() {
small_imgs.src = reader.result;
}, false);
// 调用reader.readAsDataURL()方法,把图片转成base64
reader.readAsDataURL(file);
$("img").eq(0).css("display", "block");
}, false);
}
if(img){
img.addEventListener('change', function() {
var file = this.files[0];
var reader = new FileReader();
// 监听reader对象的的onload事件,当图片加载完成时,把base64编码賦值给预览图片
reader.addEventListener("load", function() {
imgs.src = reader.result;
}, false);
// 调用reader.readAsDataURL()方法,把图片转成base64
reader.readAsDataURL(file);
$("img").eq(1).css("display", "block");
}, false);
}
</script>
<!-- 上传图片并预览的js文件 end -->
over!over!over!
最新文章
- Sqlserver 导出数据脚本
- 【金】nginx+uwsgi+django+python 应用架构部署
- MyEclipse JAX-WS Web Service
- mysql - join two derived tables
- C#中的线程二(Cotrol.BeginInvoke和Control.Invoke)
- Hosts文件的使用
- 远程桌面Default.rdp 中各个参数的含义
- mysql 日志
- 收集oracle统计信息
- mysql tinyint smallint mediumint int bigint
- 输入的不是有效的 Base-64 字符串,因为它包含非 Base-64 字符、两个以上的填充字符,或者填充字符间包含非法字符
- Unix环境高级编程
- 数组去重的三种方法及from方法
- PHP不依赖系统自动执行机制
- UESTC_神秘绑架案 CDOJ 881
- linux 命令总结(转载)
- mybatis的动态sql中collection与assoction
- MyBatis-plus 代码自动生成器
- ToolStrip和MenuStrip控件簡介及常用屬性(转)
- gradle入门(1-8)gradle 的依赖查看、依赖排除和指定版本(需要验证!)
热门文章
- C++输入一行字符串的一点小结
- multimap容器和multiset容器中的find操作
- 一个兼容性比较好的图片左右滚动的js
- 谈谈EJB是怎样公布Web Service的
- 3.改变 HTML 内容
- Process &#39;command &#39;D:\AndroidSDK\ndk-bundle\ndk-build.cmd&#39;&#39; finished with non-zero exit value 2
- js获取浏览器宽高、网页宽高、屏幕宽高、鼠标位置等(带图片说明)
- 自建 AppRTC
- PHP自定义网站根目录
- P1816 忠诚