在一个父页面中嵌入了一个iframe窗口来上传文件,怎么在文件上传后将文件路径显示到父页面的表单中

在一个父页面中嵌入了一个iframe窗口来上传文件,怎么在文件上传后将文件路径显示到父页面的表单中,第1张

a.html

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Document</title>

</head>

<body>

<iframe src="b.html" frameborder="0" width="300px" height="100px">

</iframe>

<input type="text" id='show'>

</body>

</html>

b.html

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-8">

<title>Document</title>

</head>

<body>

<input type="file" id='f'>

<input type="submit" onclick="showdir()">

</body>

<script>

function showdir () {

f=document.getElementById('f')

self.parent.document.getElementById("show").value=f.value

}

</script>

</html>

程序说明

使用说明

实例化时,第一个必要参数是file控件对象:

new QuickUpload(file)

第二个可选参数用来设置系统的默认属性,包括

属性:    默认值//说明

parameter: {},//参数对象

action:  "",//设置action

timeout: 0,//设置超时(秒为单位)

onReady: function(){},//上传准备时执行

onFinish: function(){},//上传完成时执行

onStop:  function(){},//上传停止时执行

onTimeout: function(){}//上传超时时执行

还提供了以下方法:

upload:执行上传 *** 作;

stop:停止上传 *** 作;

dispose:销毁程序。

var QuickUpload = function(file, options) {

this.file = $$(file)

this._sending = false//是否正在上传

this._timer = null//定时器

this._iframe = null//iframe对象

this._form = null//form对象

this._inputs = {}//input对象

this._fFINISH = null//完成执行函数

$$.extend(this, this._setOptions(options))

}

QuickUpload._counter = 1

QuickUpload.prototype = {

//设置默认属性

_setOptions: function(options) {

this.options = {//默认值

action:        "",//设置action

timeout:    0,//设置超时(秒为单位)

parameter:    {},//参数对象

onReady:    function(){},//上传准备时执行

onFinish:    function(){},//上传完成时执行

onStop:        function(){},//上传停止时执行

onTimeout:    function(){}//上传超时时执行

}

return $$.extend(this.options, options || {})

},

//上传文件

upload: function() {

//停止上一次上传

this.stop()

//没有文件返回

if ( !this.file || !this.file.value ) return

//可能在onReady中修改相关属性所以放前面

this.onReady()

//设置iframe,form和表单控件

this._setIframe()

this._setForm()

this._setInput()

//设置超时

if ( this.timeout > 0 ) {

this._timer = setTimeout( $$F.bind(this._timeout, this), this.timeout * 1000 )

}

//开始上传

this._form.submit()

this._sending = true

},

//设置iframe

_setIframe: function() {

if ( !this._iframe ) {

//创建iframe

var iframename = "QUICKUPLOAD_" + QuickUpload._counter++,

iframe = document.createElement( $$B.ie ? "<iframe name=\"" + iframename + "\">" : "iframe")

iframe.name = iframename

iframe.style.display = "none"

//记录完成程序方便移除

var finish = this._fFINISH = $$F.bind(this._finish, this)

//iframe加载完后执行完成程序

if ( $$B.ie ) {

iframe.attachEvent( "onload", finish )

} else {

iframe.onload = $$B.opera ? function(){ this.onload = finish } : finish

}

//插入body

var body = document.body body.insertBefore( iframe, body.childNodes[0] )

this._iframe = iframe

}

},

//设置form

_setForm: function() {

if ( !this._form ) {

var form = document.createElement('form'), file = this.file

//设置属性

$$.extend(form, {

target: this._iframe.name, method: "post", encoding: "multipart/form-data"

})

//设置样式

$$D.setStyle(form, {

padding: 0, margin: 0, border: 0,

backgroundColor: "transparent", display: "inline"

})

//提交前去掉form

file.form && $$E.addEvent(file.form, "submit", $$F.bind(this.dispose, this))

//插入form

file.parentNode.insertBefore(form, file).appendChild(file)

this._form = form

}

//action可能会修改

this._form.action = this.action

},

//设置input

_setInput: function() {

var form = this._form, oldInputs = this._inputs, newInputs = {}, name

//设置input

for ( name in this.parameter ) {

var input = form[name]

if ( !input ) {

//如果没有对应input新建一个

input = document.createElement("input")

input.name = name input.type = "hidden"

form.appendChild(input)

}

input.value = this.parameter[name]

//记录当前input

newInputs[name] = input

//删除已有记录

delete oldInputs[name]

}

//移除无用input

for ( name in oldInputs ) { form.removeChild( oldInputs[name] ) }

//保存当前input

this._inputs = newInputs

},

//停止上传

stop: function() {

if ( this._sending ) {

this._sending = false

clearTimeout(this._timer)

//重置iframe

if ( $$B.opera ) {//opera通过设置src会有问题

this._removeIframe()

} else {

this._iframe.src = ""

}

this.onStop()

}

},

//销毁程序

dispose: function() {

this._sending = false

clearTimeout(this._timer)

//清除iframe

if ( $$B.firefox ) {

setTimeout($$F.bind(this._removeIframe, this), 0)

} else {

this._removeIframe()

}

//清除form

this._removeForm()

//清除dom关联

this._inputs = this._fFINISH = this.file = null

},

//清除iframe

_removeIframe: function() {

if ( this._iframe ) {

var iframe = this._iframe

$$B.ie ? iframe.detachEvent( "onload", this._fFINISH ) : ( iframe.onload = null )

document.body.removeChild(iframe) this._iframe = null

}

},

//清除form

_removeForm: function() {

if ( this._form ) {

var form = this._form, parent = form.parentNode

if ( parent ) {

parent.insertBefore(this.file, form) parent.removeChild(form)

}

this._form = this._inputs = null

}

},

//超时函数

_timeout: function() {

if ( this._sending ) { this._sending = false this.stop() this.onTimeout() }

},

//完成函数

_finish: function() {

if ( this._sending ) { this._sending = false this.onFinish(this._iframe) }

}

}

wordpress程序是目前最流行的博客程序,在国内的使用量也是非常大的。最近看到很多新手在使用wordpress的时候,不知道怎么调用单页,而我本人在网上也没有发现这方面很详细的教程,所以这次专门来写下调用单页的 *** 作方法,虽然是很基础,但是确实是很多新手需要的。

使用wordpress调用单页一般都是在博客上放广告使用的, *** 作的方法有两种,一种是使用iframe调用,一种是使用js代码调用,下面来讲下实际 *** 作步骤。

iframe调用单页

1.既然是调用单页,那就需要有个单页,所以第一步是准备一个单页,单页也可以自己用DW(dreamweaver)制作,这里就不详细讲述了。另外也可以找到目标网页去下载,比如你看准哪个网站的单页不错,然后查看源代码,找到其单页的地址,然后用浏览器的目标另存为把网页下载下来,命名为一个随意名字就OK。鉴于有些新手可能还是不太懂,所以本人特意找到一个百度的单页做示范教程,看下图:

2.按照上图的 *** 作我们就会得到一个名为.htm的单页,加一个存放单页图片和其他文件的_files文件夹,接下来我们把这两个文件用FTP工具上传到wordpress的主题目录,路径是/wp-content/themes/,这样你用这个网址wp-content/themes/.htm去访问,就可以看到这个单页了。

3.网站有了单页,那还要知道怎么调用,调用的方法其实很简单,只需要在wordpress主题头部下面放上一段代码就可以调用了,代码:</p

align="center">

好了,现在访问下你的网站,单页效果就会出来了。当然单页不一定就要放在头部,具体放在什么地方你自己可以多试试。

js调用单页

js调用单页其实跟iframe调用差不多,就多了一个步骤,方法就是做好上面的1、2步骤以后。

1.接下来在桌面建立一个js文件(建立一个记事本,把后缀名改为.js就ok。可能有些朋友改后缀名没有效果,这是因为你的电脑隐藏了文件的扩展名,只要设置下就好了),js文件名也是随意取,姑且把它命名为“.js”。

2.用记事本打开这个.js,在里面插入代码,:

代码:

document.write(‘<iframe

src=”<span

style=”color:

ff0000”>wp-content/themes/.htm</span>”

width=”100%”<span

style=”color:

ff0000”>height=”415〃</span>

frameborder=”no”

border=”0〃

marginwidth=”0〃

marginheight=”0〃scrolling=”no”></iframe>’)

3.代码插入以后我们保存这个.js文件,然后将他上传至网站的/wp-content/themes/目录下,用wp-content/themes/.js访问下,看下能不能访问到。

4.最后一步就是在网页当中调用这段js了,调用代码如下:

<script

src=’wp-content/themes/.js’

language=’javascript’>

看到这里,相信不用解析大家也能看懂,我们只要把这段代码放到wordpress主题头部下面就ok了,访问下首页就可以看到效果了。

写在后面:这两种调用方法,个人比较倾向于js调用,因为现在百度还不能索引js代码里面的内容,而iframe调用百度已经可以收录,从百度的快照就可以看出来,因为使用单页调用的大多数站长都是做淘客,而百度有点反感淘客,所以个人建议还是使用js调用。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12077822.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存