用javascript提交form时 js错误:拒绝访问。。你如何解决的呢
而且我是用js打开的<inputfile=''>然后提交的你提出的问题,你是怎么解决的呢。谢谢了...
而且我是用js打开的<input file='' > 然后提交的
你提出的问题,你是怎么解决的呢。谢谢了 展开
你提出的问题,你是怎么解决的呢。谢谢了 展开
4个回答
推荐于2017-09-01
展开全部
安全问题不能直接用js来操作file表单的
但可以用样式的方式修改file表单的外观
【file样式】
如果有用过163网盘上传文件,就知道那个file控件就像一个按钮,但功能确实是一个file控件。
但当自己尝试修改file控件的样式时,发现单单设置file控件的样式并不能实现想要的效果。
于是我想了另一个办法,用一个button来模拟,结果发现也不行,用js根本操作不了file控件,应该是考虑到安全问题吧。
最后是参考了163网盘和muxrwc模拟126附件添加的效果,总结了这个方法:
1.指定用一个容器(例如程序中的idFile)。
容器最好指定高和宽,并且overflow为hidden,不是块级元素的最好设display为block(为了高和宽的正确呈现);
2.在容器里放一个file控件,并设置样式,使能触发弹出选择文件框的部分覆盖整个容器,并设置成全透明。
容器指定准确的高和宽就是为了能通过file控件中不多的能设置的样式来覆盖整个容器;
3.现在已经把容器模拟成file控件了,可以直接设置容器的样式来模拟设置file控件的样式了。
但可以用样式的方式修改file表单的外观
【file样式】
如果有用过163网盘上传文件,就知道那个file控件就像一个按钮,但功能确实是一个file控件。
但当自己尝试修改file控件的样式时,发现单单设置file控件的样式并不能实现想要的效果。
于是我想了另一个办法,用一个button来模拟,结果发现也不行,用js根本操作不了file控件,应该是考虑到安全问题吧。
最后是参考了163网盘和muxrwc模拟126附件添加的效果,总结了这个方法:
1.指定用一个容器(例如程序中的idFile)。
容器最好指定高和宽,并且overflow为hidden,不是块级元素的最好设display为block(为了高和宽的正确呈现);
2.在容器里放一个file控件,并设置样式,使能触发弹出选择文件框的部分覆盖整个容器,并设置成全透明。
容器指定准确的高和宽就是为了能通过file控件中不多的能设置的样式来覆盖整个容器;
3.现在已经把容器模拟成file控件了,可以直接设置容器的样式来模拟设置file控件的样式了。
参考资料: http://www.blueidea.com/common/shoutbox/redir.asp?id=11280
展开全部
为了安全考虑,浏览器不允许给input type=file赋值,出于安全的考虑(任意上传用户的文件,这样不安全)
也就是说input type=file的value属性对js来说是只读的,不能写,只能通过用户选择文件
解决的办法用户的浏览器版本很低,可以通过
还有就是自己写ActiveX上传控件
也就是说input type=file的value属性对js来说是只读的,不能写,只能通过用户选择文件
解决的办法用户的浏览器版本很低,可以通过
还有就是自己写ActiveX上传控件
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
panelwork 说的对.为了..安全考虑 要想做特殊效果只能从样式下手
不过还有个招.
你建立个iframe,iframe里建立跟你表单一样的表单.然后当外面的表单更新值的时候往iframe里的表单传.提交的时候提交iframe里的值 这样就能提交.不然就只能在css下功夫咯...
不过还有个招.
你建立个iframe,iframe里建立跟你表单一样的表单.然后当外面的表单更新值的时候往iframe里的表单传.提交的时候提交iframe里的值 这样就能提交.不然就只能在css下功夫咯...
来自:求助得到的回答
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不错,楼上的回答得很对
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询