怎么使用 js post 图片 上传?

2017-07-16 20:01:37 +08:00
 onji

http://pic.onji.cn/upload.html

这个是用 html 表单 post 会跳转到 php 文件。 点上传跳到 php 页面输出图片链接。(外链)

有没有什么办法可以不跳转,直接在本页面显示输出的图片链接吗? JS 可以,但是我不会这个。 有哪位大神可以教下吗?或者私聊也行。admin@onji.cn

jquery ajax 都不会,求大神帮助。

4590 次点击
所在节点    JavaScript
24 条回复
airyland
2017-07-16 20:02:41 +08:00
话说不会写也会搜吧
onji
2017-07-16 20:03:43 +08:00
@airyland 搜过,一下午,没解决成功。
Joan
2017-07-16 20:28:03 +08:00
http://yunzhu.iteye.com/blog/2177923
随便找了个感觉符合需求~~
onji
2017-07-16 20:28:56 +08:00
@Joan 谢谢,迟点我看看。
sparkle2015
2017-07-16 20:53:55 +08:00
1. 后台代码是你们自己控制的吗 (从图上的 url 来看,应该是的)?如果是的话,就修改后台代码,让后台在接收图片后,重新渲染 "http://pic.onji.cn/upload.html" 这个 url,并把图片的 url 显示在此页面的 img 元素中,而不是 redirect_to 到新的 url。

1. 第二种方法,在前端用 ajax 请求,后台接收图片后,发现如果是 ajax 请求,则把图片 url 以 json 形式返回,前端拿到 url 后把它的值设置到 img 的 src 属性中。[示例代码]( https://github.com/baurine/rails-study/blob/master/upload_file_demo/app/views/resumes/new.html.erb)。
Maxbee
2017-07-16 21:22:26 +08:00
之前遇到这样的问题。也是尝试了一段时间才试出来。你可以用 input 标签 type 是 file 类型的,选择图片之后监听 change 事件 ,再用 ajax post 图片数据就行。这样页面不会跳转
popok
2017-07-16 21:41:27 +08:00
ajax,post 完后,把返回的图片链接地址插到 image 里去
romotc
2017-07-16 21:47:53 +08:00
base64(img)
justtery
2017-07-16 21:48:54 +08:00
去百度搜 bootstrap file input 给你想要的,照着 demo 写就好了
chairuosen
2017-07-16 22:12:17 +08:00
这里本质的原因是原生 post 是跳页面的,后续步骤你控制不了,ajax 是不跳页面的,请求过程是可以控制的。
xiaoz
2017-07-16 22:28:22 +08:00
还是用 ajax 实现最简单
mingyun
2017-07-16 22:57:00 +08:00
ajax formdata
test4zhou
2017-07-16 22:58:01 +08:00
转 base64
qiayue
2017-07-16 23:00:16 +08:00
有很多 js 图片上传控件,能够显示上传进度,比如 http://www.plupload.com/
tcsky
2017-07-16 23:12:05 +08:00
v1024
2017-07-16 23:47:58 +08:00
表单 target 指向一个隐藏的 iframe 的 id
gdtv
2017-07-17 00:05:03 +08:00
@romotc
@test4zhou
base64 的方法似乎挺耗资源
romotc
2017-07-17 08:34:04 +08:00
@gdtv 等你的业务发展到需要考虑这点性能之前早就换到七牛了
dollarbai
2017-07-17 09:40:31 +08:00
ajax formdata 这个可以解决问题,不过低版本浏览器不支持这个 formdata 对象。
对于低版本浏览器,就可以使用前后端公用一种加密解密方式(比如 base64 )
AJian
2017-07-17 10:07:20 +08:00
用 iframe 可以吧

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/375745

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX