`
jkfzero
  • 浏览: 105189 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

用jquery的click或者trigger("click")模拟文件域点击不好使。

阅读更多

原帖http://bbs.blueidea.com/viewthread.php?tid=1227402

 

 

<input type="file" style="border:1px solid blue;color:red;background:green;font:bold 12px '隶书';height:18px;width:160px">

 

 

可以看到,上传框带有两个控件:一个文本框和一个按钮。定义的样式对文本框全部生效,对于按钮,只有边框样式、字体大小和外观尺寸生效。看来直接用CSS定义它的外观是行不通的。

我们知道,大部分控件都有一个单击(click)事件句柄,上传框在单击"浏览..."按钮时会弹出"选择文件"对话框,如果我们自己模拟一个上传框:一个文本框(<input type="text">)和一个按钮(<input type="button">或<button>Text</button>),在单击自定义按钮时同时触发上传框的click事件让它弹出"选择文件"对话框... ...于是有:

 

<style>
.file{border:1px solid #333333;color:#666666;background:#eeeeee;font:normal 12px Tahoma;height:18px}
</style>
<input type="text" class="file" id="f_file"><input type="button" value="上传文件" class="file" onClick="t_file.click()">
<input name="upload" type="file" id="t_file" onchange="f_file.value=this.value" style="display:none">

 

 

在点击"上传文件"按钮时执行t_file.click(),当上传框的值有所改变时通过onchange事件句柄执行f_file.value=this.value,即保持真正的上传框与模拟的上传框的值同步更新,style="display:none"让真正的上传框隐藏,使模拟的文件上传框能以假乱真------问题似乎解决了,不过,把代码放到表单中测试一下看看:

 

 

 

<style>
.file{border:1px solid #333333;color:#666666;background:#eeeeee;font:normal 12px Tahoma;height:18px}
</style>
<form method="post" action="" enctype="multipart/form-data"><input type="text" class="file" id="f_file"><input type="button" value="上传文件" class="file" onClick="t_file.click()">
<input name="upload" type="file" id="t_file" onchange="f_file.value=this.value">
<input type="submit">
</form>

 

 

点击"上传文件"按钮后再提交表单,可以看到,真正的上传框的内容被清空了,意思就是说,这样模拟出来的上传框没有任何意义,因为没办法上传文件(记得上期《电脑》报上有关于这个的文章,我想作者肯定没放到表单中测试过)。
之所以是这个结果,估计是因为微软出于安全方面的考虑,只有当鼠标真正单击在上传控件的按钮上浏览到的文件才可以上传(否则,只要你进入我的页面,我就可以随心所欲的得到你的私密文件)。看来此路又是不通,不过不要丧气,运行一下下面的代码看看:

 

<script>
function fclick(obj){
  with(obj){
    style.posTop=event.srcElement.offsetTop	//设置透明上传框的Y坐标跟模拟按钮的Y坐标对齐
    style.posLeft=event.x-offsetWidth/2		//设置透明上传框的X坐标为鼠标在X轴上的坐标加上它的宽的一半(确保点击时能点中透明上传框的按钮控件),这里只是提供一种思路,其实还可以更精确的控制它的X坐标范围
  }
}
</script>
<style>
input{border:1px solid #333333;color:#666666;background:#eeeeee;font:normal 12px Tahoma;height:18px}
</style>
<form method="post" action="" enctype="multipart/form-data">
<input id="f_file">&nbsp;<input type="button" onmouseover="fclick(t_file)" value="选择上传文件">
<input name="upload" type="file" style="position:absolute;filter:alpha(opacity=0);width:30px;" id="t_file" onchange="f_file.value=this.value" hidefocus>
<br><input type="submit" value="提交">
</form>
 

 

直接看代码一时可能还明白不过来,可以把上传框的透明度增加到百分之三十再看看效果(或者看这里的讨论:http://bbs.blueidea.com/viewthread.php?tid=1118701):

 

<script>
function fclick(obj){
  with(obj){
    style.posTop=event.srcElement.offsetTop
    style.posLeft=event.x-offsetWidth/2
  }
}
</script>
<style>
input{border:1px solid #333333;color:#666666;background:#eeeeee;font:normal 12px Tahoma;height:18px}
</style>
<form method="post" action="" enctype="multipart/form-data">
<input id="f_file">&nbsp;<input type="button" onmouseover="fclick(t_file)" value="选择上传文件">
<input name="upload" type="file" style="position:absolute;filter:alpha(opacity=30);width:30px;" id="t_file" onchange="f_file.value=this.value" hidefocus>
<br><input type="submit" value="提交">
</form>

 

提示:要更精确的控制透明上传框的X坐标,可把脚本部分修改一下:

 

 

<script>
function fclick(obj){
  with(obj){
    style.posTop=event.srcElement.offsetTop
    var x=event.x-offsetWidth/2
    if(x<event.srcElement.offsetLeft)x=event.srcElement.offsetLeft
    if(x>event.srcElement.offsetLeft+event.srcElement.offsetWidth-offsetWidth)x=event.srcElement.offsetLeft+event.srcElement.offsetWidth-offsetWidth
    style.posLeft=x
  }
}
</script>
<style>
input{border:1px solid #333333;color:#666666;background:#eeeeee;font:normal 12px Tahoma;height:18px}
</style>
<form method="post" action="" enctype="multipart/form-data">
<input id="f_file">&nbsp;<input type="button" onmouseover="fclick(t_file)" value="选择上传文件">
<input name="upload" type="file" style="position:absolute;filter:alpha(opacity=30);width:30px;" id="t_file" onchange="f_file.value=this.value" hidefocus>
<br><input type="submit" value="提交">
</form>
 
分享到:
评论

相关推荐

    jquery上传文件点击input上传文件样式代码

    本主题聚焦于利用jQuery来改进文件上传功能,尤其是针对`&lt;input type="file"&gt;`元素的样式和交互。在传统的HTML文件上传输入框中,用户通常会看到一个简单的文本按钮,点击后弹出文件选择对话框。然而,这样的设计...

    使用jquery模拟a标签的click事件无法实现跳转的解决

    问题描述 最近在使用jquery模拟a标签的click事件,无法触发其默认行为。...jquery内部实现click或trigger方法时,并未真正模拟用户点击事件,只是模拟了事件对象及冒泡的触发。(最后附有jquery实现源

    jquery的js文件

    2. **事件处理**:jQuery的事件处理方式非常直观,如`$(selector).click(function() {...})`定义点击事件,`$(selector).on('mouseover', function() {...})`绑定鼠标悬停事件。此外,还有`off()`用于移除事件,以及...

    jquery文本,以文本格式保存的jquery文件

    `.on()`方法用于绑定事件处理器,如`$("#element").on("click", function() {...})`会在元素被点击时执行指定的函数。同时,`.off()`可以移除事件监听器,`.trigger()`可以触发已绑定的事件。 **文档处理**涉及到...

    javascript触发模拟鼠标点击事件

    除此之外,文章提到了jQuery库中的`event.trigger`方法,这是一个封装过的事件触发方式,它通过模拟实现了事件触发的功能。当我们想要触发某个元素上的事件时,jQuery会自动寻找绑定在该元素上的对应事件处理函数并...

    jquery点击弹出窗口特效

    本教程将深入探讨如何使用jQuery实现点击按钮后弹出窗口的特效,并且这个弹出窗口可以支持图文并茂的排列方式,以及通过iframe加载外部内容。 首先,我们需要在HTML页面中设置一个按钮元素,该元素将触发弹出窗口的...

    jQuery中值得注意的trigger方法浅析

    介绍 trigger方法的功能是在所选择的元素上触发指定...在jquery中可以使用trigger完成。 $(#btn).trigger(click)//触发id为btn的click事件 $(#btn).click()//简写 触发自定义事件 trigger不仅能触发浏览器支持的这些

    Jquery 模拟用户点击超链接或者按钮的方法

    ”是一个非常简单的示例,演示了如何使用jQuery的`trigger()`方法来模拟点击一个ID为"a"的元素。这里,“#a”是一个CSS选择器,用于选中页面上ID属性为"a"的元素。`trigger()`函数是jQuery的一个核心函数,它允许...

    JQuery实战视频教程中需要使用的JQuery文件

    **jQuery实战视频教程中需要使用的JQuery文件** 在学习JavaScript库和框架的过程中,jQuery是一个非常重要的工具,尤其对于初学者来说,它简化了许多DOM操作、事件处理和Ajax交互。本教程将聚焦于jQuery的核心概念...

    jQuery CSS3点击向上拉伸切换特效.zip

    为了确保广泛兼容,可以考虑引入polyfill库,或者使用jQuery的动画方法来模拟类似效果。 此外,这个特效还可以进一步扩展,例如添加自定义的动画效果,或者与其它前端框架(如Bootstrap)集成,以适应更复杂的项目...

    jQuery.event.trigger()的简单解释

    下面,我们来看一个使用jQuery.event.trigger()函数触发自定义事件的例子。首先,我们通过$(document).on()函数注册了一个名为"autoRefreshEvent123456"的自定义事件,并定义了这个事件的处理函数。这个函数会接收四...

    jquery-3.7.1.zip web组件

    3. **事件处理**:jQuery简化了事件绑定,如`.on("click", function() {...})`用于监听点击事件,`.off()`用于解除事件绑定,`.trigger()`则可以触发特定事件。 4. **动画效果**:jQuery的`.fadeIn()`, `.slideUp()...

    jQuery实现当按下回车键时绑定点击事件

    在jQuery中,有几种方法可以绑定事件处理函数,如`.bind()`、`.on()`等方法,同样也有`.trigger()`、`.click()`等方法用于触发事件。 根据文档提供的代码,实现按下回车键触发点击事件主要涉及到了`keydown`事件...

    jquery trigger伪造a标签的click事件取代window.open方法

    但出于用户体验和浏览器安全限制的考虑,有时候开发者可能希望使用更为精细和可控的方式来处理点击事件,比如使用jQuery的trigger()方法来触发a标签的click事件,从而取代window.open()。 首先,我们需要了解什么是...

    jquery例子大全 jquery demo

    jQuery对象提供了许多方法,如 `.html()` 用于获取或设置元素的HTML内容,`.css()` 用于修改样式,`.click()` 用于绑定点击事件等。 ### 二、jQuery 动画效果 jQuery 提供了一系列的动画效果,如 `.fadeIn()`, `....

    jquery文件与插件

    jQuery提供了一种统一的方式来处理浏览器事件,如`.on('click', function() {...})`绑定点击事件,`.off()`移除事件,`.trigger('event')`触发事件。此外,还有`.hover()`用于处理悬停事件,`.change()`处理表单元素...

    JQuery事件Demo

    2. **`.click()`**: 这是jQuery对`'click'`事件的简写,用法与`.on('click')`相同。例如,点击按钮弹出提示: ```javascript $('#myButton').click(function() { alert('Button clicked!'); }); ``` ### 二、...

    jquery3.2.1官方正版

    - **引入方式**: 可以通过 `&lt;script&gt;` 标签直接引入 jQuery,或者使用CDN(内容分发网络)链接。在HTML文件中,可以这样引入: ```html &lt;script src="path/to/jquery-3.2.1.min.js"&gt; ``` - **NoConflict模式**: 当与...

    JQuery框架软件包下载

    通过`.on()`方法,可以绑定多种类型的事件,如点击事件(`click`)、鼠标悬停事件(`hover`)等。同时,jQuery还提供了`.trigger()`方法,可以手动触发已绑定的事件。 **动画效果** jQuery的动画效果是其魅力之一...

Global site tag (gtag.js) - Google Analytics