菜鸟笔记-9月10日(关于jquery的一些应用)

1,Js文件中调用其它Js函数的方法

  在项目开发过程中,也许你会遇这样的情况。在某一Js文件中需要完成某一功能,但这一功能的大部分代码在另外一个Js文件中已经完成了,自己只需要调用这个方法再加上几句代码就可以实现所需的功能。我们知道,在html中,利用
<script language="javascript" type="text/javascript" src="../script.js"></script>
引入的两个js是不可以相互调用的。那么该如何解决呢?当然,你可以将代码通通copy过来,这样会让你的b.js会变得很长,也许已经影响到了你对b.js的定位了,检查,维护都会变得麻烦.
  例如有这样一个html,里面有一个按钮,当按下时调用b.js文件中的方法b()。而b()中又要调用a.js文件中的方法a()。那我们应该怎么做呢?
  首先,我们在html中引入b.js,并在</body>之后加入引用语句。必须注意,将要引入的Js文件代码放在</body>下面。

< html >
 
< body >
    
< input type ="button" value ="ok" onclick ="javascript:b()" >
 
</ body >

<!-- 这里引用要放在body下面 -->
< script language ="JAVASCRIPT" src ='b.js' ></ script >

</ html >


  b.js文件中引入a.js,内容如下:

new_element=document.createElement("script");
new_element.setAttribute("type","text/javascript");
new_element.setAttribute("src","a.js");// 在这里引入了a.js
document.body.appendChild(new_element);

function b()  {
     a();
}


  在b.js文件中前4行代码中我们引入了a.js文件,并在第7行代码中调用了a.js代码中的a()方法。

  让我们来分析一下关键的几句代码:首先,我们利用document.createElement("script")生成了一个script的标签,设置其type属性为text/javascript,src为a.js(这里的a.js同b.js放在同一个目录,也可放在不同的目录)。最后将这个标签动态地加入body中。如此一来,我们就可以调用到不同js文件中的方法了。

注意:<scriptlanguage="JAVASCRIPT" src='b.js'></script>一定要放在body下面。
因为在b.js中用到了body(document.body.appendChild(new_element);)
如果将引如b.js的代码放在body上面,也就是说,
进入页面后,还没有生成body就已经执行b.js里的document.body.appendChild(new_element);了。
这时body不存在就会抛javascript错误。

 

 

2,关于jquery异步验证用户是否存在

前台:

<head runat="server">
    <title></title>
     <script type="text/javascript" src="http://js.ccement.com/Price/js/jquery-1.6.1.min.js"></script>
     <script type="text/javascript">
         $(document).ready(function () {
             $("#txtName").blur(function () {
                 $.ajax({
                     type: "GET",(或type:"POST")
                     url: "getUserName.ashx"/("AjaxUserInfoModify.aspx"),         
                     dataType: "html",
                     data: "userName=" + $("#txtName").val(),
                     beforeSend: function (XMLHttpRequest) {
                         $("#Gettxt").text("正在查询...");
                     },
                     success: function (msg) { $("#Gettxt").html(msg); $("#Gettxt").css("color", "red"); },
                     complete: function (XMLHttpRequest, textStatus) { },
                     error: function () { }
                 }
                 );
             });
         });
     </script>
</head>
<body>
    <div id="txt">
    <input type="text" id="txtName" name="txtName"/>
    </div>
    <div id="Gettxt"></div>
</body>

getUserName.ashx页面:

<%@ WebHandler Language="C#" Class="getUserName" %>

using System;
using System.Web;

public class getUserName : IHttpHandler {
   
    public void ProcessRequest (HttpContext context) {
        context.Response.ContentType = "text/plain";
        string userName =context.Request.QueryString["userName"].ToString();

     //如果为post的话

     //string userName=context.Request.Params["userName"].ToString();
        if (userName == "James Hao")
        {
            context.Response.Write("用户名已经存在!");
        }
        else
        {
            context.Response.Write("您可以使用此用户名");
        }

      
    }
 
    public bool IsReusable {
        get {
            return false;
        }
    }

}

或者页面如此:

页面AjaxUserInfoModify.aspx

后台代码

Code void Page_Load(object sender, EventArgs e)
    {
        string userName
= Request.QueryString[ " userName " ].ToString ();
       
if (userName == " James Hao " )
        {
            Response.Write (
" 用户名已经存在! " );
        }
       
else
        {
            Response.Write (
" 您可以使用此用户名! " );
        }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值