【JS教程】​JS小功能代码片段(二)

JS小功能代码片段(一)

JS小功能代码片段(二)

16、在窗口滚动时自动加载内容

var loading = false;
$(window).scroll(function(){ 
    if((($(window).scrollTop() + $(window).height())+250) >= $(document).height()){ 
        if(loading == false){ 
            loading = true; 
            $('#loadingbar').css("display","block"); 
            $.get("load.php?start = "+$('#loaded_max').val(), function(loaded){ 
                $('body').append(loaded); 
                $('#loaded_max').val(parseInt($('#loaded_max').val()) + 50); 
                $('#loadingbar').css("display","none"); 
                loading = false; 
            }); 
        } 
    } 
}); 
$(document).ready(function() { 
    $('#loaded_max').val(50); 
});

17、为input表单增加自动提示功能

方法一:

浏览器引入了许多的HTML5 特性其中我最喜欢的一个就是为input元素引入了placeholder属性,placeholder属性显示引导性文字直到输入框获取输入焦点,当有了用户输入内容后引导性内容将会自动隐藏。

但是placeholder的样式如颜色,将根据不同浏览器显示不同效果,如下截图,密码input表单添加了改属性。左侧为chrome,右侧为ie10。


方法二:

在input中加入autotip属性,但是看了上面的方法一之后,我觉得还不如加上placeholder属性来得更好。当浏览器不支持placeholder时,再平稳过渡到下面方法二。

版本1:

1 <span style="font-size: 12px;">var Autotip = function(ele,valClass,blankClass,tip){<br>        var tip = tip || ele.attr("autotip") || "";<br>        var valClass = valClass || "valClass";<br>        var blankClass = blankClass || "blankClass";<br>        ele.val(tip).addClass("color-gray1");<br>        ele.on("focus",function(){<br>            if (ele.val() == tip){<br>                ele.val("").removeClass(blankClass).addClass(valClass);<br>            }<br>        });<br>        ele.on("blur",function(){<br>            if (!ele.val() || !ele.val().trim()){<br>                ele.val(tip).removeClass(valClass).addClass(blankClass);<br>            }<br>        });<br>    };<br>    var mobileAutoTip = new Autotip($(".mobile-input"),"color-gray2","color-gray1");<br></span>

版本2:

1 <span style="font-size: 12px;">var autoTip = function(){<br>        $(this).on("focus",function(){<br>            $(this).addClass("focus");<br>            if ($(this).val() == $(this).attr("autoTip") || !$(this).val() || $(this).val().trim()) {<br>                $(this).val("");<br>            }<br>        });<br><br>        $(this).on("blur",function(){<br>            if (!$(this).val().trim()) {<br>                $(this).val($(this).attr("autoTip"));<br>                $(this).removeClass("focus");<br>            }<br>        });<br>}<br></span>


最终版:

(1、当input有默认value值时,input失去焦点,修改后的value值为空或无效时,恢复默认value值)
(2、增加调用方式:1>可以直接用类方法调用;2>可以用new来调用)

18、为input表单提供email域名自动赋值提示

需求:html5 input里的新的list属性,当用户输入'@'后为用户提示域名信息。如图:

【JS教程】​JS小功能代码片段(二)

这个属性在safari中不支持,从而在App中也无法支持,估计只能在chrome中使用了。就当学习了。贴上代码,大致思路是监听用户输入'@'后,构造datalist,并关联到input上。依赖jquery。

代码示例:

1 <span style="font-size: 12px;">(function(){<br>    var emails = [{domain: '@qq.com', label: 'qq邮箱'}, <br>                {domain: '@163.com',  label: '163邮箱'},<br>                {domain: '@126.com', label: '126邮箱'},<br>                {domain: '@hotmail.com', label: 'hotmail邮箱'},<br>                {domain: '@sina.com', label:'sina邮箱'},<br>                {domain: '@gmail.com ',label:'gmail邮箱'}, <br>                {domain: '@139.com', label: '139邮箱'}, <br>                {domain:'@yahoo.com.cn', label: 'yahoo中国邮箱'}];<br>                <br>    var addEmailHelp = function(id, otherAddress){<br>        var inputObj = $('input#' + id);<br>        if(inputObj.length == 0){<br>            return;<br>        }<br>        <br>        inputObj.keyup(function (ev) {<br>            var val = $(inputObj).val();<br>            var lastInputKey = val.charAt(val.length - 1);<br>            <br>            if (lastInputKey == '@') {<br>                var indexOfAt = val.indexOf('@');<br>                var username = val.substring(0, indexOfAt);<br><br>                if ($('datalist#emailList').length > 0) {<br>                    $('datalist#emailList').remove();<br>                }<br><br>                $(inputObj).parent().append('<datalist id="emailList"></datalist>');<br>                for (var in emails) {<br>                    $('datalist#emailList').append('<option value="' + username + emails[i].domain + '" label="' + emails[i].label + '" />');<br>                }<br>                <br>                if(otherAddress != null && typeof otherAddress != 'undefined'){<br>                    for (var in otherAddress) {<br>                    $('datalist#emailList').append('<option value="' + username + otherAddress[i].domain + '" label="' + otherAddress[i].label + '" />');<br>                    }<br>                }<br><br>                $(inputObj).attr('list''emailList');<br>            }<br>        })<br>    };<br>    <br>    window.addEmailHelp = addEmailHelp;<br>})();<br></span>

1 <span style="font-size: 12px;"><html> <br><head><br>    <script type="text/javascript" src="jquery-1.7.2.js"></script><br>    <script type="text/javascript" src="test.js"></script>     <br>    <script type="text/javascript">    <br>        $(document).ready(function(){       <br>            addEmailHelp('test');   <br>        });           <br>    </script> <br>    </head> <br>    <body> <br>    email : <input id="test" type="text" required/> <br>    </body> <br></html><br></span>

19、简单向上滚动幻灯

        <div class="news_box">
            <ul>
                <li><a href="#">当季主题11111111111111111111111111111111111111111</a></li>
                <li><a href="#">当季主题22222222222222222222222222222222222222222</a></li>
                <li><a href="#">当季主题33333333333333333333333333333333333333333</a></li>
                <li><a href="#">当季主题44444444444444444444444444444444444444444</a></li>
                <li><a href="#">当季主题55555555555555555555555555555555555555555</a></li>
            </ul>
        </div>

var NewsSlide = {
    InitNewsSlide : function(){
        var that = this;
        that.newsSlideData = {
            liArr : [],
            height : parseInt($(".news_box li").css("height")),
            index : 1
        };
        $(".news_box ul li").each(function(){
            that.newsSlideData.liArr.push("<li>" + $(this).html() + "</li>");
        });
        that.InitNewsSlideInterval();
        $(".news_box ul li").live("mouseover",function(){
            that.clearNewsSlideInterval();
        });
        $(".news_box ul li").live("mouseout",function(){
            that.InitNewsSlideInterval();
        });
    },
    InitNewsSlideInterval : function(){
        var that = this;
        var to = 2000;
        that.newsSlideInterval = setInterval(function(){
            that.slideNewsSlide();
        },to);
    },
    clearNewsSlideInterval : function(){
        var that = this;
        if (that.newsSlideInterval){
            clearInterval(that.newsSlideInterval);
            that.newsSlideInterval = null;
        }
    },
    slideNewsSlide : function(){
        var speed = 600;
        var top = this.newsSlideData.height * (-1);
        $(".news_box ul").append(this.newsSlideData.liArr[this.newsSlideData.index - 1]);
        this.newsSlideData.index += 1;
        this.newsSlideData.index >= this.newsSlideData.liArr.length && (this.newsSlideData.index = 1);
        //top == (this.newsSlideData.liArr.length - 1) * this.newsSlideData.height * (-1) && (top = 0);
        $(".news_box li").eq(0).animate({"margin-top" : top + "px"},speed,function(){
            $(this).remove();
        });
    }
};

20、js点击复制文字和图片

  • 复制文字

1 <textarea name="inquiryContact1" id="inquiryContact1" rows="15" cols="60" readonly="readonly"></textarea>  
2 <div id="inquiryInfoDIV" style="display:none">  
3     <s:property value="inquiryContact" escape="false"/>  
4 </div>
01  var i = 0 ;   
02     function copyContact(){  
03         var contat = document.getElementById("inquiryContact1").value;  
04         window.clipboardData.setData('text', contat);  
05         if(window.clipboardData.getData('text')==''){  
06             if(i==1){  
07                 alert("复制失败,请手动Ctrl+C快捷键复制!");  
08             }else{  
09                 alert("复制失败,请重新复制!");  
10                 i = 1;  
11             }  
12         }else{  
13              alert("内容已经复制到剪贴板!");  
14         }  
15     }
  • 复制图片

01 var oPopup = window.createPopup();  
02 function ButtonClick(div)  
03 {  
04     //var div = document.getElementById('divId');  
05     div.contentEditable = 'true';  
06     var controlRange;  
07     if (document.body.createControlRange) {  
08         controlRange = document.body.createControlRange();  
09         controlRange.addElement(div);  
10         controlRange.execCommand('Copy');  
11     }  
12     div.contentEditable = 'false';  
13 }
1   <div id="divId1">  
2         <img src="F:/2012070518474964.jpg" onclick="ButtonClick(this)">  
3   </div>

21、简单模板解析小插件

01 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
02         "http://www.w3.org/TR/html4/loose.dtd">
03 <html>
04 <head>
05     <meta charset="utf-8">
06     <title>简单模板匹配</title>
07     <script type="text/javascript">
08         var Template = function(tpl,data){
09             this.tpl = typeof tpl != "undefined" ? tpl : '';
10             this.data =  typeof data != "undefined" ? data : null;
11             this.filds = [];
12             this.str = '';
13
14
15             this.create = function(tpl){
16                 typeof tpl != "undefined" && (this.tpl = tpl);
17                 var _rgExp = /{(.*?)}/g;
18                 this.filds = this.tpl.match(_rgExp);
19                 for(var i=0; i < this.filds.length; i++){
20                     this.filds[i] = this.filds[i];
21                 }
22             };
23
24
25             this.append = function(data){
26                 typeof data != "undefined" && (this.data = data);
27                 if(parseInt(this.data.length) > 0){
28                     this.str = this.tpl;
29                     for(var i=0; i < this.data.length; i++){
30                         this.str = this.filds[i] && this.str.replace(this.filds[i],this.data[i]);
31                     }
32                 }else if(typeof this.data == "object"){
33                     this.str = this.tpl;
34                     for(var i=0; i < this.filds.length; i++){
35                         var _fild = this.filds[i].replace("{","").replace("}","");
36                         this.str = this.data[_fild] && this.str.replace(this.filds[i],this.data[_fild]);
37                     }
38                 }
39             };
40
41
42             this.tpl && this.create();
43             this.data && this.append();
44         };
45
46
47         var tpl = "hello,this is{字段1}and{字段2}!";
48         var data1 = {
49             "字段1" : "---测试数据1---",
50             "字段2" : "---测试数据1---"
51         };
52         var data2 = ["---测试数据2---","---测试数据2---"];
53         var data3 = ["---测试数据3---","---测试数据3---"];
54         var data4 = ["---测试数据4---","---测试数据4---"];
55
56
57         var template1 = new Template(tpl,data1);
58         var template2 = new Template(tpl,data2);
59         var template3 = new Template();
60         template3.create(tpl);
61         template3.append(data3);
62         var template4 = new Template(tpl);
63         template4.append(data4);
64
65
66         document.write("参数为json数据 : " + template1.str);
67         document.write("<br> 参数为array数据 : " + template2.str);
68         document.write("<br> 利用内置create 和 append方法生成字符串 : " + template3.str);
69         document.write("<br> 利用内置append方法生成字符串 : " + template4.str);
70     </script>
71 </head>
72 <body>
73
74
75 </body>
76 </html>

22、JS调用打印机

第一种方法:指定不打印区域

使用CSS,定义一个.noprint的class,将不打印的内容放入这个class内。

详细如下:

<style media=print type="text/css"> 
.noprint{visibility:hidden} 
</style> 
要打印的内容。哈哈!
<p class="noprint">将不打印的代码放在这里。</p>
<a href="javascrīpt:window.print()" target="_self">打印</a>

第二种方法:指定打印区域

把要打印的内容放入一个 span或div,然后通过一个函数打印。

<span id='div1'>把要打印的内容放这里</span>
<p>所有内容</p>
<div id="div2">div2的内容</div>
<a href="javascrīpt:printme()" target="_self">打印</a>
<scrīpt language="javascrīpt">
function printme()
{
document.body.innerHTML=document.getElementById('div1').innerHTML+'<br/>'+document.getElementById('div2').innerHTML;
window.print();
}
</scrīpt>

如果要打印的只是整个页面中的一小部分,就最好采用第二种方法。

第三种方法:如果要打印的页面排版和原web页面相差很大,采用此种方法。

点打印按钮弹出新窗口,把需要打印的内容显示到新窗口中,在新窗口中调用window.print()方法,然后自动关闭新窗口。

1、控制"纵打"、 横打”和“页面的边距。

(1)

<script defer>function SetPrintSettings() {// -- advanced featuresfactory.printing.SetMarginMeasure(2) // measure margins in inchesfactory.SetPageRange(false, 1, 3) // need pages from 1 to 3factory.printing.printer = "HP DeskJet 870C"factory.printing.copies = 2factory.printing.collate = truefactory.printing.paperSize = "A4"factory.printing.paperSource = "Manual feed"
// -- basic featuresfactory.printing.header = "This is MeadCo"factory.printing.footer = "Advanced Printing by ScriptX"factory.printing.portrait = falsefactory.printing.leftMargin = 1.0factory.printing.topMargin = 1.0factory.printing.rightMargin = 1.0factory.printing.bottomMargin = 1.0}</script>

(2)

<script language="javascript">function printsetup(){// 打印页面设置wb.execwb(8,1);}function printpreview(){// 打印页面预览wb.execwb(7,1);}
function printit(){if (confirm('确定打印吗?')) {wb.execwb(6,6)}}</script></head><body><OBJECT classid="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2" height=0 id=wb name=wb width=0></OBJECT><input type=button name=button_print value="打印" onclick="javascript:printit()"><input type=button name=button_setup value="打印页面设置" onclick="javascript:printsetup();"><input type=button name=button_show value="打印预览" onclick="javascript:printpreview();"><input type=button name=button_fh value="关闭" onclick="javascript:window.close();">

------------------------------------------------
关于这个组件还有其他的用法,列举如下:
WebBrowser.ExecWB(1,1) 打开
Web.ExecWB(2,1) 关闭现在所有的IE窗口,并打开一个新窗口
Web.ExecWB(4,1) 保存网页
Web.ExecWB(6,1) 打印
Web.ExecWB(7,1) 打印预览
Web.ExecWB(8,1) 打印页面设置
Web.ExecWB(10,1) 查看页面属性
Web.ExecWB(15,1) 好像是撤销,有待确认
Web.ExecWB(17,1) 全选
Web.ExecWB(22,1) 刷新
Web.ExecWB(45,1) 关闭窗体无提示

2、分页打印

<HTML>
<HEAD>
<STYLE>  
P {page-break-after: always}
</STYLE>
</HEAD>
<BODY>
<%while not rs.eof%>
<P><%=rs(0)%></P>
<%rs.movenext%>
<%wend%>
</BODY>
</HTML>

3、ASP页面打印时如何去掉页面底部的路径和顶端的页码编号

(1)ie的文件-〉页面设置-〉讲里面的页眉页脚里面的东西都去掉,打印就不出来了。
(2)

<HTML><HEAD><TITLE> New Document </TITLE><META NAME="Generator" CONTENT="EditPlus"><META NAME="Author" CONTENT="YC"><script language="VBScript">dim hkey_root,hkey_path,hkey_keyhkey_root="HKEY_CURRENT_USER"hkey_path="\Software\Microsoft\Internet Explorer\PageSetup"'//设置网页打印的页眉页脚为空function pagesetup_null()on error resume nextSet RegWsh = CreateObject("WScript.Shell")hkey_key="\header"  RegWsh.RegWrite hkey_root+hkey_path+hkey_key,""hkey_key="\footer"RegWsh.RegWrite hkey_root+hkey_path+hkey_key,""end function'//设置网页打印的页眉页脚为默认值function pagesetup_default()on error resume nextSet RegWsh = CreateObject("WScript.Shell")hkey_key="\header"  RegWsh.RegWrite hkey_root+hkey_path+hkey_key,"&w&b页码,&p/&P"hkey_key="\footer"RegWsh.RegWrite hkey_root+hkey_path+hkey_key,"&u&b&d"end function</script></HEAD>
<BODY><br/><br/><br/><br/><br/><br/><p align=center><input type="button" value="清空页码" onclick=pagesetup_null()> <input type="button" value="恢复页吗"
onclick=pagesetup_default()><br/></p></BODY></HTML>

4、浮动帧打印

<SCRIPT LANGUAGE=javascript>
function button1_onclick() {
var odoc=window.iframe1.document;
var r=odoc.body.createTextRange();
var stxt=r.htmlText;
alert(stxt)
var pwin=window.open("","print");
pwin.document.write(stxt);
pwin.print();
}
</SCRIPT>

5、用FileSystem组件实现WEB应用中的本地特定打印

<script Language=VBScript>
function print_onclick //打印函数
dim label
label=document.printinfo.label.value //获得HTML页面的数据
set objfs=CreateObject("Scripting.FileSystemObject") //创建FileSystem组件对象的实例
set objprinter=objfs.CreateTextFile ("LPT1:",true) //建立与打印机的连接
objprinter.Writeline("__________________________________") //输出打印的内容
objprinter.Writeline("| |")
objprinter.Writeline("| 您打印的数据是:"&label& " |”)
objprinter.Writeline("| |")
objprinter.Writeline("|_________________________________|")
objprinter.close //断开与打印机的连接
set objprinter=nothing
set objfs=nothing // 关闭FileSystem组件对象
end function
</script>

服务器端脚本:
<%………
set conn=server.CreateObject ("adodb.connection")
conn.Open "DSN=name;UID=XXXX;PWD=XXXX;"
set rs=server.CreateObject("adodb.recordset")
rs.Open(“select ……”),conn,1,1
……….%> //与数据库进行交互
HTML页面编码:

<HTML>
………
<FORM ID=printinfo NAME="printinfo" >
<INPUT type="button" value="打印>>" id=print name=print > //调用打印函数
<INPUT type=hidden id=text1 name=label value=<%=………%>> //保存服务器端传来的数据
………
</HTML>

第四种方法:去除页眉页脚

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>PcyearSeo</title>
<head>
<!--关键代码部分-->
<script language="javascript" type="text/javascript"> 
function doPrint() { 
bdhtml=window.document.body.innerHTML; 
sprnstr="<!--startprint-->"; 
eprnstr="<!--endprint-->"; 
prnhtml=bdhtml.substr(bdhtml.indexOf(sprnstr)+17); 
prnhtml=prnhtml.substring(0,prnhtml.indexOf(eprnstr)); 
window.document.body.innerHTML=prnhtml; 
window.print(); 
} 
var hkey_root,hkey_path,hkey_key 
hkey_root="HKEY_CURRENT_USER" 
hkey_path="\Software\Microsoft\Internet Explorer\PageSetup\ " 
function pagesetup_null(){ 
try{ 
var RegWsh=new ActiveXObject("WScript.Shell") 
hkey_key="header" 
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"") 
hkey_key="footer" 
RegWsh.RegWrite(hkey_root+hkey_path+hkey_key,"") 
}catch(e){} 
} 
</script> 
<!--关键代码部分-->
</HEAD> 
<BODY> 
<DIV align=center> 
<p>
<!--关键代码部分-->
<OBJECT id="WebBrowser" classid="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2" height="0" width="0" VIEWASTEXT></OBJECT>
<!--关键代码部分-->
您打印内容开始:
</p>
<p> 
<!--startprint-->
<div style="border:1px solid #999999; width:auto;"><img src="2010723115926746.jpg"/></div>
<!--endprint-->
</p>
<p>打印的内容结束</p>
<p class="noprint">
<!--class="noprint"的作用是标示不需要打印的地方,任何一个标签的class属性都可以设置,用于
去除
不需要打印的地方-->
<INPUT onclick=javascript:doPrint() type=button value=打印 name=button_print /> 
</p>
</DIV>
</body>
</html>

23、通过js发送HTTP请求的几种方法 

var httpAdapter;
002     //创建一个httpAdapter对象
003     function GethttpAdapterRequest() 
004     {
005         //httpAdapter = window.ActiveXObject ? new ActiveXObject("Microsoft.XMLHTTP") : new httpAdapterRequest();
006          return window.ActiveXObject ? new ActiveXObject("Microsoft.XMLHTTP") : new XMLHttpRequest();
007     }
008
009     //以Get方式发送请求,默认Content-Type为"text/xml; charset=gb2312"
010     this.GetData = function(url)
011     {
012         httpAdapter = GethttpAdapterRequest();
013    httpAdapter.Open("GET",url, false); 
014    httpAdapter.SetRequestHeader ("Content-Type","text/xml; charset=gb2312"); 
015 //   httpAdapter.SetRequestHeader ("SOAPAction","http://tempuri.org/getStr"); 
016    httpAdapter.Send(context); 
017    return httpAdapter;
018     }
019
020     //以POST方式发送请求,默认Content-Type为"application/x-www-form-urlencoded"
021     this.PostData = function (url,context)
022     {
023         httpAdapter = GethttpAdapterRequest();
024         httpAdapter.Open("POST",url, false); 
025    httpAdapter.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
026 //   httpAdapter.SetRequestHeader ("SOAPAction","http://tempuri.org/getStr"); 
027    httpAdapter.Send(context); 
028    return httpAdapter;
029     
030
031
032     this.GetDataInAsync = function (url,callbackMethod)
033     {
034         httpAdapter = GethttpAdapterRequest();
035    httpAdapter.Open("GET",url, true); 
036    httpAdapter.SetRequestHeader ("Content-Type","text/xml; charset=gb2312"); 
037 //   httpAdapter.SetRequestHeader ("SOAPAction","http://tempuri.org/getStr"); 
038    httpAdapter.Send(context); 
039    httpAdapter.onreadystatechange = callbackMethod; 
040     }
041
042     this.PostDataInAsync = function (url,context,callbackMethod)
043     {
044         httpAdapter = GethttpAdapterRequest();
045         httpAdapter.Open("POST",url, true); 
046    httpAdapter.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
047 //   httpAdapter.SetRequestHeader ("SOAPAction","http://tempuri.org/getStr"); 
048    httpAdapter.Send(context); 
049    httpAdapter.onreadystatechange = callbackMethod;
050     }
051
052     //获取指定地址的域名
053     this.GetHost = function(url) 
054     {
055         var host = "null";
056         var ArryHost=new Array();
057         if(typeof url == "undefined"|| null == url)
058         
059             url = window.location.href;
060         }
061         var regex = /.*\:\/\/([^\/]*).*/; 
062         var match = url.match(regex); 
063         if(typeof match != "undefined" && null != match)
064         {
065             ArryHost = match[1].split(/:/);
066             host =ArryHost[0];
067         }
068         return host;
069     }
070
071     //获取当前地址的域名
072     this.GetLocalHost=function()
073     {
074        return GetHost(document.URL);
075     }
076
077
078   以前每次写AJAX请求总要写好几个JS函数,包括创建XMLHttpRequest对象、发送请求、成功后的处理函数和失败后的处理函数,下面的JS是把这些东西重构之后参数化的形式,然后放到一个单独的net.js里,后续使用只需引入这个JS,然后新建相应的对象和处理函数即可,可以直接拿来使用
079
080    var net = new Object();
081    net.READY_STATE_UNINITIALIZED = 0;
082    net.READY_STATE_LOADING = 1;
083    net.READY_STATE_LOADED = 2;
084    net.READY_STATE_INTERACTIVE = 3;
085    net.READY_STATE_COMPLETE = 4;
086
087
088
089
090
091    net.ContentLoader = function(url,onload,onerror,method,params,contentType)
092    {
093
094     this.req = null;
095     this.onload = onload;
096     this.onerror = (onerror) ? onerror : this.defaultError;
097     this.loadXMLDoc(url,method,params,contentType);
098    }
099
100
101
102    net.ContentLoader.prototype = {
103
104
105
106    onReadyState: function(){
107
108      var req = this.req;
109      var ready = req.readyState;
110      if(ready == net.READY_STATE_COMPLETE)
111      {
112         var httpStatus = req.status;
113      if(httpStatus == 200 || httpStatus == 0)
114          this.onload.call(this);
115         else
116          this.onerror.call(this);
117             }
118     },
119
120     defaultError: function(){
121
122      alert("error in fetching data!! readyState=="+this.req.readyState+"\n\nstatus="+this.req.status
123           +" \n\nheaders"+this.req.getAllResponseHeaders());
124
125     }
126
127
128
129    }
130
131
132
133    net.ContentLoader.prototype.loadXMLDoc = function(url,method,params,contentType){
134
135      if(!method)  //如果没有传入method 参数值,则默认为GET
136      {
137          method = "GET";
138      }
139      if (!contentType && method=="POST"){
140          contentType="application/x-www-form-urlencoded;";
141      }
142
143      if(window.XMLHttpRequest)
144      {
145         this.req = new XMLHttpRequest();
146       }
147      else if(window.ActiveXObject)
148      {
149         this.req = new ActiveXObject("Microsoft.XMLHTTP");
150      }
151      if(this.req)
152      {
153
154
155        try{
156             var loader = this;   
157             this.req.onreadystatechange = function(){
158                 loader.onReadyState.call(loader);
159             }
160             this.req.open(method,url,true); 
161             //POST方法需要设置的属性
162             if (contentType){
163                this.req.setRequestHeader("Content-Type", contentType);
164             
165             this.req.send(params);
166
167        }catch(err)
168       
169           this.onerror.call(this);
170       }
171     }
172  }
173
174
175
176     代码内容不在做过多解释,如果你对JS面向对象和prototype不太熟悉的话请查阅相关书籍,下面演示如何使用:
177
178 1. 把上述内容单独放到一个文件net.js(名称可自己定义)
179
180 2. 在要使用的JSP页面上引入这个net.js  即  <script src="net.js"> </script>
181
182 3. 发送请求GET方式
183
184    new  net.ContentLoader("http://localhost:8080/CfgWeb/AppLogin.do",getMessage);  
185
186    其中第一个参数是请求的后台程序地址,第二个参数是请求成功后的处理函数(自己定义)
187
188    后面的参数可省略,也可自己添加第三个参数(请求不成功的处理函数)
189
190    function getMessage()
191
192    {
193
194         alert(this.req.responseText);  //简单的输出返回结果的字符串形式
195
196         alert(this.req.responseXML);   //XML形式,后面就根据你的需要解析这个XML了
197
198    }
199
200 4. 发送POST请求
201
202    new net.ContentLoader("http://localhost:8080/CfgWeb/AppLogin.do?formAction=autoComplete",getMessage,null,"POST","&userName=wangwei&password=123" );
203
204    function getMessage()
205
206    {
207
208         alert(this.req.responseText);  //简单的输出返回结果的字符串形式
209
210         alert(this.req.responseXML);   //XML形式,后面就根据你的需要解析这个XML了
211
212    }

24、JS读取本地文件及目录的方法

Javascript是网页制作中离不开的脚本语言,依靠它,一个网页的内容才生动活泼、富有朝气。但也许你还没有发现并应用它的一些更高级

的功能吧?比如,对文件和文件夹进行读、写和删除,就象在VB、VC等高级语言中经常做的工作一样。怎么样,你是否需要了解这方面的知

识?那就请跟我来,本文将详细描述如何使用Javascript语言进行文件操作。

一、功能实现核心:FileSystemObject 对象

其实,要在Javascript中实现文件操作功能,主要就是依靠FileSystemobject对象。在详细介绍FileSystemobject对象的各个属性和方法的

使用细节前,先来看看这个对象包括哪些相关对象和集合:

二、FileSystemObject编程三部曲

使用FileSystemObject 对象进行编程很简单,一般要经过如下的步骤: 创建FileSystemObject对象、应用相关方法、访问对象相关属性 。

(一)创建FileSystemObject对象

创建FileSystemObject对象的代码只要1行:

var fso = new ActiveXObject("Scripting.FileSystemObject");

上述代码执行后,fso就成为一个FileSystemObject对象实例。

(二)应用相关方法

创建对象实例后,就可以使用对象的相关方法了。比如,使用CreateTextFile方法创建一个文本文件:

var fso = new ActiveXObject("Scripting.FileSystemObject");

var f1 = fso.createtextfile("c:\\myjstest.txt",true");

(三)访问对象相关属性

要访问对象的相关属性,首先要建立指向对象的句柄,这就要通过get系列方法实现:GetDrive负责获取驱动器信息,GetFolder负责获取文

件夹信息,GetFile负责获取文件信息。比如,指向下面的代码后,f1就成为指向文件c:\test.txt的句柄:

var fso = new ActiveXObject("Scripting.FileSystemObject");

var f1 = fso.GetFile("c:\\myjstest.txt");

然后,使用f1访问对象的相关属性。比如:

var fso = new ActiveXObject("Scripting.FileSystemObject");

var f1 = fso.GetFile("c:\\myjstest.txt");

alert("File last modified: " + f1.DateLastModified);

执行上面最后一句后,将显示c:\myjstest.txt的最后修改日期属性值。

但有一点请注意:对于使用create方法建立的对象,就不必再使用get方法获取对象句柄了,这时直接使用create方法建立的句柄名称就可以

var fso = new ActiveXObject("Scripting.FileSystemObject");

var f1 = fso.createtextfile("c:\\myjstest.txt",true");

alert("File last modified: " + f1.DateLastModified);

三、操作驱动器(Drives)

使用FileSystemObject对象来编程操作驱动器(Drives)和文件夹(Folders)很容易,这就象在Windows文件浏览器中对文件进行交互操作一样

,比如:拷贝、移动文件夹,获取文件夹的属性。

(一)Drives对象属性

Drive对象负责收集系统中的物理或逻辑驱动器资源内容,它具有如下属性:

l TotalSize:以字节(byte)为单位计算的驱动器大小。

l AvailableSpace或FreeSpace:以字节(byte)为单位计算的驱动器可用空间。

l DriveLetter:驱动器字母。

l DriveType:驱动器类型,取值为:removable(移动介质)、fixed(固定介质)、network(网络资源)、CD-ROM或者RAM盘。

l SerialNumber:驱动器的系列码。

l FileSystem:所在驱动器的文件系统类型,取值为FAT、FAT32和NTFS。

l IsReady:驱动器是否可用。

l ShareName:共享名称。

l VolumeName:卷标名称。

l Path和RootFolder:驱动器的路径或者根目录名称。

(二)Drive对象操作例程

下面的例程显示驱动器C的卷标、总容量和可用空间等信息:

var fso, drv, s ="";

fso = new ActiveXObject("Scripting.FileSystemObject");

drv = fso.GetDrive(fso.GetDriveName("c:\\"));

s += "Drive C:" + " - ";

s += drv.VolumeName + "\n";

s += "Total Space: " + drv.TotalSize / 1024;

s += " Kb" + "\n";

s += "Free Space: " + drv.FreeSpace / 1024;

s += " Kb" + "\n";

alert(s);


四、操作文件夹(Folders)

涉及到文件夹的操作包括创建、移动、删除以及获取相关属性。

(一)Folder对象的相关属性和方法列表

(二)Folder对象操作例程

下面的例程将练习获取父文件夹名称、创建文件夹、删除文件夹、判断是否为根目录等操作:

var fso, fldr, s = "";

// 创建FileSystemObject对象实例

fso = new ActiveXObject("Scripting.FileSystemObject");

// 获取Drive 对象

fldr = fso.GetFolder("c:\\");

// 显示父目录名称

alert("Parent folder name is: " + fldr + "\n");

// 显示所在drive名称

alert("Contained on drive " + fldr.Drive + "\n");

// 判断是否为根目录

if (fldr.IsRootFolder)

alert("This is the root folder.");

else

alert("This folder isn't a root folder.");

alert("\n\n");

// 创建新文件夹

fso.CreateFolder ("C:\\Bogus");

alert("Created folder C:\\Bogus" + "\n");

// 显示文件夹基础名称,不包含路径名

alert("Basename = " + fso.GetBaseName("c:\\bogus") + "\n");

// 删除创建的文件夹

fso.DeleteFolder ("C:\\Bogus");

alert("Deleted folder C:\\Bogus" + "\n");

五、操作文件(Files)

对文件进行的操作要比以上介绍的驱动器(Drive)和文件夹(Folder)操作复杂些,基本上分为以下两个类别:对文件的创建、拷贝、移动、删

除操作和对文件内容的创建、添加、删除和读取操作。下面分别详细介绍。

(一)创建文件

一共有3种方法可用于创建一个空文本文件,这种文件有时候也叫做文本流(text stream)。

第一种是使用CreateTextFile方法。代码如下:

var fso, f1;

fso = new ActiveXObject("Scripting.FileSystemObject");

f1 = fso.CreateTextFile("c:\\testfile.txt", true);

第二种是使用OpenTextFile方法,并添加上ForWriting属性,ForWriting的值为2。代码如下:

var fso, ts;

var ForWriting= 2;

fso = new ActiveXObject("Scripting.FileSystemObject");

ts = fso.OpenTextFile("c:\\test.txt", ForWriting, true);

第三种是使用OpenAsTextStream方法,同样要设置好ForWriting属性。代码如下:

var fso, f1, ts;

var ForWriting = 2;

fso = 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方法。

(三)创建文件及添加数据例程

下面的代码将创建文件、添加数据、关闭文件几个步骤结合起来进行应用:

var fso, tf;

fso = new ActiveXObject("Scripting.FileSystemObject");

// 创建新文件

tf = fso.CreateTextFile("c:\\testfile.txt", true);

// 填写数据,并增加换行符

tf.WriteLine("Testing 1, 2, 3.") ;

// 增加3个空行

tf.WriteBlankLines(3);

// 填写一行,不带换行符

tf.Write ("This is a test.");

// 关闭文件

tf.Close();

(四)读取文件内容

从文本文件中读取数据要使用TextStream对象的Read、ReadLine或ReadAll 方法。Read方法用于读取文件中指定数量的字符;ReadLine方法

读取一整行,但不包括换行符;ReadAll方法则读取文本文件的整个内容。读取的内容存放于字符串变量中,用于显示、分析。在使用Read或

ReadLine方法读取文件内容时,如果要跳过一些部分,就要用到Skip或SkipLine方法。

下面的代码演示打开文件、填写数据,然后读取数据:

var fso, f1, ts, s;

var ForReading = 1;

fso = new ActiveXObject("Scripting.FileSystemObject");

// 创建文件

f1 = fso.CreateTextFile("c:\\testfile.txt", true);

// 填写一行数据

f1.WriteLine("Hello World");

f1.WriteBlankLines(1);

// 关闭文件

f1.Close();

// 打开文件

ts = fso.OpenTextFile("c:\\testfile.txt", ForReading);

// 读取文件一行内容到字符串

s = ts.ReadLine();

// 显示字符串信息

alert("File contents = ‘" + s + "‘");

// 关闭文件

ts.Close();

(五)移动、拷贝和删除文件

对于以上三种文件操作,Javascript各有两种对应的方法:File.Move 或 FileSystemObject.MoveFile用于移动文件;File.Copy 或

FileSystemObject.CopyFile用于拷贝文件;File.Delete 或 FileSystemObject.DeleteFile用于删除文件。

下面的代码演示在驱动器C的根目录下创建一个文本文件,填写一些内容,然后将文件移动到\tmp目录下,再在目录\temp下面建立一个文件

拷贝,最后删除这两个目录的文件:

var fso, f1, f2, s;

fso = new ActiveXObject("Scripting.FileSystemObject");

f1 = fso.CreateTextFile("c:\\testfile.txt", true);

// 写一行

f1.Write("This is a test.");

// 关闭文件

f1.Close();

// 获取C:\根目录下的文件句柄

f2 = fso.GetFile("c:\\testfile.txt");

// 移动文件到\tmp目录下

f2.Move ("c:\\tmp\\testfile.txt");

// 拷贝文件到\temp目录下

f2.Copy ("c:\\temp\\testfile.txt");

// 获取文件句柄

f2 = fso.GetFile("c:\\tmp\\testfile.txt");

f3 = fso.GetFile("c:\\temp\\testfile.txt");

// 删除文件

f2.Delete();

f3.Delete();

六、结 语

通过以上对FileSystemObject的各种对象、属性和方法的介绍和示例,相信你已经对如何使用JavaScript语言在页面中操作驱动器、文件和

文件夹有了清晰的认识。但是上述提及的例程都非常简单,要全面、灵活地掌握JavaScript文件操作技术,还需要大量的实践练习。而且还

有一点提醒大家,由于涉及到在浏览器中进行文件读写这样的高级操作,对于默认的浏览器安全级别而言,在代码运行前都会有一个信息提示。

你可能感兴趣的:(【JS教程】​JS小功能代码片段(二))