js 如何给控件files添加单个文件

JavaScript011

js 如何给控件files添加单个文件,第1张

创建文件 一共有3种方法可用于创建一个空文本文件,这种文件有时候也叫做文本流(text stream)。 第一种是使用CreateTextFile方法。代码如下: var fso, f1fso = new ActiveXObject("Scripting.FileSystemObject")f1 = fso.CreateTextFile("c://testfile.txt", true)第二种是使用OpenTextFile方法,并添加上ForWriting属性,ForWriting的值为2。代码如下: var fso, tsvar ForWriting= 2fso = new ActiveXObject("Scripting.FileSystemObject")ts = fso.OpenTextFile("c://test.txt", ForWriting, true)第三种是使用OpenAsTextStream方法,同样要设置好ForWriting属性。代码如下: var fso, f1, tsvar ForWriting = 2fso = new ActiveXObject("Scripting.FileSystemObject")fso.CreateTextFile ("c://test1.txt")f1 = fso.GetFile("c://test1.txt")ts = f1.OpenAsTextStream(ForWriting, true)(二)添加数据到文件 当文件被创建后,一般要按照“打开文件->填写数据->关闭文件”的步骤实现添加数据到文件的目的。 打开文件可使用FileSystemObject对象的OpenTextFile方法,或者使用File对象的OpenAsTextStream方法。 填写数据要使用到TextStream对象的Write、WriteLine或者WriteBlankLines方法。在同是实现写入数据的功能下,这3者的区别在于:Write方法不在写入数据末尾添加新换行符,WriteLine方法要在最后添加一个新换行符,而WriteBlankLines则增加一个或者多个空行。 关闭文件可使用TextStream对象的Close方法。

代码如下:

<script type="text/javascript">

//FX获取文件路径方法

function readFileFirefox(fileBrowser) {

try {

netscape.security.PrivilegeManager.enablePrivilege("UniversalXPConnect")

}

catch (e) {

alert('无法访问本地文件,由于浏览器安全设置。为了克服这一点,请按照下列步骤操作:(1)在地址栏输入"about:config"(2) 右键点击并选择 New->Boolean(3) 输入"signed.applets.codebase_principal_support" (不含引号)作为一个新的首选项的名称(4) 点击OK并试着重新加载文件')

return

}

var fileName=fileBrowser.value//这一步就能得到客户端完整路径。下面的是否判断的太复杂,还有下面得到ie的也很复杂。

var file = Components.classes["@mozilla.org/file/local1"]

.createInstance(Components.interfaces.nsILocalFile)

try {

// Back slashes for windows

file.initWithPath( fileName.replace(/\//g, "\\\\") )

}

catch(e) {

if (e.result!=Components.results.NS_ERROR_FILE_UNRECOGNIZED_PATH) throw e

alert("File '" + fileName + "' cannot be loaded: relative paths are not allowed. Please provide an absolute path to this file.")

return

}

if ( file.exists() == false ) {

alert("File '" + fileName + "' not found.")

return

}

return file.path

}

//根据不同浏览器获取路径

function getvl(){

//判断浏览器

var Sys = {}

var ua = navigator.userAgent.toLowerCase()

var s

(s = ua.match(/msie ([\d.]+)/)) ? Sys.ie = s[1] :

(s = ua.match(/firefox\/([\d.]+)/)) ? Sys.firefox = s[1] :

(s = ua.match(/chrome\/([\d.]+)/)) ? Sys.chrome = s[1] :

(s = ua.match(/opera.([\d.]+)/)) ? Sys.opera = s[1] :

(s = ua.match(/version\/([\d.]+).*safari/)) ? Sys.safari = s[1] : 0

var file_url=""

if(Sys.ie<="6.0"){

//ie5.5,ie6.0

file_url = document.getElementById("file").value

}else if(Sys.ie>="7.0"){

//ie7,ie8

var file = document.getElementById("file")

file.select()

file_url = document.selection.createRange().text

}else if(Sys.firefox){

//fx

//file_url = document.getElementById("file").files[0].getAsDataURL()//获取的路径为FF识别的加密字符串

file_url = readFileFirefox(document.getElementById("file"))

}

//alert(file_url)

document.getElementById("text").innerHTML="获取文件域完整路径为:"+file_url

}

</script>

<h1>JS获取文件域完整路径的方法,兼容不同浏览器</h1>

<div id="text" style="color:#f00"></div>

<input type="file" id="file" />

<input name="" type="button" value="获取" onClick="getvl()">

<!DOCTYPE HTML>

<html>

<head>

<meta charset="UTF-8">

<title>Droid</title>

<style type="text/css">

ul li {

float: left

list-style: none

padding-right: 10px

}

</style>

<script type="text/javascript" src="jquery-1.8.0.min.js"></script>

<script type="text/javascript">

$ (function ()

    {

    var oUll = $ ("#ul"), FR, source = $ (':file')

    if (!!(FR = $ (window).prop ('FileReader')))

    {

    var fr = new FR ()

    $ ("#btn").click (function ()

    {

     var file = source.prop ('files')[0]

    if (!file)

    {

    return false

    }

    var aLi = $ ("<li></li>")

    var aImg = $ ("<img />")

    oUll.append (aLi)

    aLi.append (aImg)

    var imgs = $ ("img")

    fr.onloadend = function (e)

    {

    imgs.eq (imgs.length - 1).attr ('src', e.target.result)

    source.val ('')

    }

    fr.readAsDataURL (file)

    })

    }

    })

</script>

</head>

<body>

<input type="file" name="file" />

<input id="btn" type="button" value="添加" />

<ul id="ul"></ul>

</body>

</html>