JS获取文件上传的图片并进行重命名上传

js本身无法直接将原图片进行重命名,但可以通过建立新文件的方式简介重命名文件,修改和重塑的区别在于本质上文件存在是否单一。


css:

div {

				padding: 5px;
				margin: 0 auto;
				text-align: center;
			}

			#mybtn,
			#clearall {
				width: 100px;
				height: 30px;
				font-size: 18px;
				background-color: #00a0e9;
				border: none;
				text-align: center;
				color: #FFF;
			}

			#prevw {
				width: 200px;
				height: 200px;
			}

			#imgshow {
				width: 400px;
				height: 300px;
				background-image: url(imgupload.jpg);
				background-size: 100% 100%;
			}

			#myfile {
				opacity: 0;
				width: 400px;
				height: 300px;
			}



html:

<div id="imgshow">
			<input type="file" onchange="show(this)" name="myfile" id="myfile" value="" />
		</div>
		<div>
			<button id="clearall">重置</button>
			<button id="mybtn">上传</button>
		</div>



js:

//获取文件对象
			var myfile = document.getElementById('myfile').files[0];
			//选中后立即显示图片
			function show(file) {
				// FileReader对象用于读取文件
				var reader = new FileReader(); 				
				//读取File对象的数据
				reader.onload = function(e) {
					$('#imgshow').css("background-image", "url(" + e.target.result + ")");
				}
				reader.readAsDataURL(file.files[0]);
			}


			$("#mybtn").click(function() {
				//获取文件上传文件的文件名和扩展名
				if (myfile.files[0] == undefined) {
					alert('未上传任何文件!');
				} else {
					//创建新文件对象
					var newfile = new File([myfile], new Date().getTime() + ".jpg", {
						type: "image/jpeg"
					});
					//获取上传文件的文件名
					div.innerHTML = div.innerHTML + '<span style="color:#FF0000;">文件名:' + newfile.name + '</span><br>';

					//异步上传时用到的formDate储存
					var formData = new FormData();
					//将fileList[0]添加进去
					formData.append('file', newfile);
					//异步
					$.ajax({
						url: '',
						type: 'POST',
						data: formData,
						contentType: false,
						processData: false,
						async: true,
						success: function(data) {
							console.log("success");
						}
					})

				}
			})


			//点击后重置所有效果
			$("#clearall").click(function() {
				$("#myfile").val("");
				$('#imgshow').css("background-image", "url(imgupload.jpg)");
			});

浏览器访问:

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: PHP AJAX上传文件是一种非常流行的技术,可以轻松地实现文件上传功能。AJAX可以将文件上传过程分解为几个步骤,然后每一步都可以单独进行处理,使得上传更为方便快捷。 上传文件的过程括文件的选择、上传过程和上传结果的显示。首先需要在HTML页面上添加一个文件上传的表单,然后使用JavaScript代码来调用PHP脚本并传递提交表单的数据。在后台的PHP脚本中,需要先验证文件的大小和类型,确保上传文件的安全性。如果验证通过,则将文件上传到服务器上,并返回上传结果给前端。在上传过程中,可以通过实时展示上传进度和上传结果,来提高用户体验。 PHP AJAX上传文件的优点是可以实现多文件同时上传、以及实时上传进度的展示,同时也可以进行数据的验证和处理。但是需要注意的是,如果上传的文件太大或者上传时间过长,可能会对服务器造成压力。因此,在上传大文件时,需要适当调整服务器的配置,以保证上传的高效性和稳定性。 ### 回答2: php ajax 上传文件是指使用Ajax技术,通过PHP后台实现文件上传功能。Ajax是一种异步请求方式,可以在不刷新整个页面的情况下与服务器进行通信。而PHP是一种后台语言,可以处理数据并生成动态内容。 实现php ajax上传文件的方法括以下步骤: 1. 编写HTML页面,文件上传表单和Ajax代码。 2. 使用JavaScript获取上传文件的数据,并将其发送到服务器。 3. 在PHP后台处理文件上传请求,括检测上传文件的类型、大小和重命名等。 4. 将上传的文件保存到指定位置,并向客户端返回上传结果。 需要注意的是,为了防止上传文件被滥用和攻击,应对上传文件的格式、大小和文件名等进行限制和验证,同时应对上传文件的存储路径进行限制和保护。 除此之外,php ajax上传文件还可以实现多文件上传上传进度条等功能,提高用户体验和交互性。 ### 回答3: PHP和Ajax可以结合使用来实现上传文件的功能。在HTML的form表单中,可以加入上传文件的input标签,然后在后台的PHP文件中实现文件上传的处理。 使用Ajax,可以通过Javascript获取上传文件的表单对象,然后将其序列化为FormData,再通过Ajax异步传递到后台的PHP文件中进行处理。通过Ajax上传文件可以实现不刷新页面就可以进行文件上传的功能。 在PHP文件中,可以通过$_FILES全局变量来获取上传的文件信息,括文件名、文件类型、文件大小等。同时,还需要对上传的文件进行相关的安全性验证,比如文件类型、大小、路径等。 在实现文件上传过程中,需要考虑上传的文件是否过大、是否有安全隐患等问题。为此,可以在上传文件前调用Ajax异步获取上传文件的信息,然后在PHP后台进行安全性验证和处理。 综上所述,PHP Ajax上传文件需要结合HTML表单、Javascript和PHP后台文件进行多级处理和验证,才能实现完整的上传文件功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Deeeelete

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值