网络编程 
首页 > 网络编程 > 浏览文章

ajax实现无刷新省市县三级联动

(编辑:jimmy 日期: 2024/11/28 浏览:3 次 )

本文实例为大家分享了ajax实现无刷新省市县三级联动的具体代码,供大家参考,具体内容如下

效果图:

ajax实现无刷新省市县三级联动

实现代码:

1、html:

<html>
<head>
 <title></title>
  <style type="text/css">
  select
  {
   width: 150px;
  }
 </style>
 <script src="/UploadFiles/2021-04-02/Jquery1.7.js">

2、WebService1.asmx

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;


namespace 省市县三级联动
{
 /// <summary>
 /// WebService1 的摘要说明
 /// </summary>
 [WebService(Namespace = "http://tempuri.org/")]
 [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
 [System.ComponentModel.ToolboxItem(false)]
 // 若要允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务,请取消对下行的注释。
  [System.Web.Script.Services.ScriptService]
 public class WebService1 : System.Web.Services.WebService
 {


  [WebMethod]
  public string HelloWorld()
  {
   return "Hello World";
  }
  [WebMethod]
  public List<Model.province> GetProvince()
  {
   BLL.province bpro = new BLL.province();
   List<Model.province> list = bpro.GetListModel();
   return list;
  }
  [WebMethod]
  public List<Model.city> GetCItyByPro(string proid)
  {
   BLL.city bcity = new BLL.city();
   List<Model.city> list = bcity.GetListModel("father='" + proid + "'");
   return list;
  }
  [WebMethod]
  public List<Model.area> GetAreaByCity(string cityid)
  {
   BLL.area barea = new BLL.area();
   List<Model.area> list = barea.GetListModel("father='" + cityid + "'");
   return list;
  }
 }
}

在三层的Bll层中的city.cs和area.cs中分别添加以下属性

//city.cs:
 public List<Model.city> GetListModel(string strsql)
  {
   return dal.GetListModel(strsql);
  }
//area.cs:
  public List<Model.area> GetListModel(string strsql)
  {
   return dal.GetListModel(strsql);
  }

在三层的DAL层中的city.cs和area.cs中分别添加以下方法

//city.cs:
public System.Collections.Generic.List<Model.city> GetListModel(string strsql)
  {
   System.Collections.Generic.List<Model.city> list = new System.Collections.Generic.List<Model.city>();
   DataTable dt = GetList(strsql).Tables[0];
   foreach (DataRow row in dt.Rows)
   {
    Model.city mcity = new Model.city();
    mcity.id = Convert.ToInt32(row["id"]);
    mcity.cityID = row["cityID"].ToString();
    mcity.cityname = row["cityname"].ToString();
    list.Add(mcity);
   }
   return list;
  }
//area.cs:
 public System.Collections.Generic.List<Model.area> GetListModel(string strsql)
  {
   DataTable dt = GetList(strsql).Tables[0];
   System.Collections.Generic.List<Model.area> list = new System.Collections.Generic.List<Model.area>();
   foreach (DataRow row in dt.Rows)
   {
    Model.area marea = new Model.area()
    {
     id = Convert.ToInt32(row["id"]),
     areaID = row["areaID"].ToString(),
     areaname = row["areaname"].ToString()
    };
    list.Add(marea);
   }
   return list;
  }

以上就是本文的全部内容,希望对大家的学习有所帮助。

上一篇:ajax无刷新分页的简单实现
下一篇:Ajax验证用户的唯一性
高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 网站地图 SiteMap