jquery省市二级联动
很多同学在进行编程学习时缺乏系统学习的资料。本页面基于jquery省市二级联动内容,从基础理论到综合实战,通过实用的知识类文章,标准的编程教程,丰富的视频课程,为您在jquery省市二级联动相关知识领域提供全面立体的资料补充。同时还包含 j2ee是什么、jar格式、java 的知识内容,欢迎查阅!
jquery省市二级联动相关知识
-
基于jQuery+JSON的省市联动效果省市区联动下拉效果在WEB中应用非常广泛,尤其在一些会员信息系统、电商网站最为常见。开发者一般使用Ajax实现无刷新下拉联动。本文将讲述,利用jQuery插件,通过读取JSON数据,实现无刷新动态下拉省市二(三)级联动效果。HTML首先在head中载入jquery库和cityselect插件。12<scripttype="text/javascript"src="js/jquery.js"></script><scripttype="text/javascript"src="js/jquery.cityselect.js"></script>接下来,我们在#city中,放置三个select,并且三个select分别设置class属性为:prov、city、dist,分别表示省、市、区(县)三个下拉框。注意如果只想实现省市二级联动,则去掉第三个dist的select即可。12345&
-
省市级联jquery和jsp //province.js文件 /* 省市级联 */ $._cityInfo = [{"n":"北京市","c":["北京市"]},{"n":"天津市","c":["天津市"]},{"n":"上海市","c":["上海市"]},{"n":"重庆市","c":["重庆市"]},{"n":"河北省","c"
-
jQuery实现 三级联动--省市县1.遍历省 在省的一列追加遍历出来的省2.遍历市2.1 根据省的索引来选择对应的市2.2 清空上一回选择的市和县2.3 如果省的索引大于 0 ,使其为 0 ,才能正常的遍历市,否则不能正常匹配2.4 在市的一列后边追加遍历出来的市3.遍历县3.1 根据市的索引来选择对应的县3.2 清空上一回选择的县3.3 如果市的索引大于 0 ,使其为 0 ,才能正常的遍历县,否则不能正常匹配3.4 在县的一列后边追加遍历出来的县现有三个省的数组var aProvince = ["河北省","山西省","湖北省"];var aCity = [ ["石家庄市", "张家口市", "承德市", "秦皇岛市"],
-
jQuery实现 三级联动--省市县1.遍历省 在省的一列追加遍历出来的省2.遍历市2.1 根据省的索引来选择对应的市2.2 清空上一回选择的市和县2.3 如果省的索引大于 0 ,使其为 0 ,才能正常的遍历市,否则不能正常匹配2.4 在市的一列后边追加遍历出来的市3.遍历县3.1 根据市的索引来选择对应的县3.2 清空上一回选择的县3.3 如果市的索引大于 0 ,使其为 0 ,才能正常的遍历县,否则不能正常匹配3.4 在县的一列后边追加遍历出来的县现有三个省的数组var aProvince = ["河北省","山西省","湖北省"];var aCity = [ ["石家庄市", "张家口市", "承德市", "秦皇岛市"],
jquery省市二级联动相关课程
jquery省市二级联动相关教程
- 启动二级缓存 在 Hibernate 的主配置文件中启动并指定二级缓存的实现者;<property name="cache.use_structured_entries">true</property><property name="cache.region.factory_class">org.hibernate.cache.ehcache.EhCacheRegionFactory</property>添加 EhCache 相关的 JAR 包。这些 JAR 包都可以在下载的 Hibernate 框架包的 lib 文件夹中找到;ehcache-core-2.4.3.jar;hibernate-ehcache-4.2.0.Final.jar。在项目的 src 中添加 EhCache 缓存框架的配置文件 ehcache.xml;这个配置文件可以在下载的 Hibernate 框架包中的 project 目录下的 etc 中找到。此配置文件中的内容用来配置缓存管理相关信息。<ehcache> <diskStore path="java.io.tmpdir"/> <defaultCache maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true" /> </ehcache> 配置说明:maxElementsInMemory: 缓存最大数目;eternal : 缓存是否持久;overflowToDisk : 是否保存到磁盘,当系统当机时;timeToIdleSeconds : 当缓存闲置 n 秒后销毁;timeToLiveSeconds : 当缓存存活 n 秒后销毁。在需要缓存的实体类上添加 @cache 注解 @Cache(usage=CacheConcurrencyStrategy.TRANSACTIONAL,include="all",region="student") 只有被 @Cache 注解的实体才会被存储进二级缓存中,此注解有一个 usage 属性,用来配置缓存的策略,是一个枚举类型,有如下几种选择:CacheConcurrencyStrategy.NONE;CacheConcurrencyStrategy.NONSTRICT_READ_WRITE: 非严格读写缓存;CacheConcurrencyStrategy.READ_ONLY: 只读缓存;CacheConcurrencyStrategy.READ_WRITE: 读写缓存;CacheConcurrencyStrategy.TRANSACTIONAL: 事务缓存。Region 指定二级缓存中的区域名,默认为类或者集合的名字。include 有几个选项,non-lazy 当属性延迟抓取打开时,标记为 lazy=“true” 的实体的属性可能无法被缓存。做完上面的事情后,再执行前面的两个 Session 对象查询同一个学生的代码,再查看控制台上的信息:Hibernate: select student0_.stuId as stuId1_1_0_, student0_.classRoomId as classRoo5_1_0_, student0_.stuName as stuName2_1_0_, student0_.stuPassword as stuPassw3_1_0_, student0_.stuSex as stuSex4_1_0_ from Student student0_ where student0_.stuId=?学生姓名:Hibernate--------------第二次查询------------------学生姓名:Hibernate第一次查询时,需要发送 SQL 请求,第二查询时,不再发送 SQL 请求,因为查询过的信息已经被存储在了二级缓存中,Hibernate 会直接从缓存查询。二级缓存并不支持缓存 Blob 类型的数据。
- 3. 级联删除 前面讲解双向一对多的时候,也提到了级联删除。最大的印象就是,如果双方都打开了级联删除,删除时就如同推倒了多米诺骨牌的第一张牌,整个数据链都会删除。多对多关联比一对多关联多了一张中间表,在进行级联删除的时候,到底会发生什么事情?在此也有必要拿出来说一说。为了不让事情的发展如山崩一样不可控制,先打开学生类的级联操作功能:private Set<Course> courses=new HashSet<Course>(); @ManyToMany(targetEntity = Course.class,cascade=CascadeType.ALL) @JoinTable(name = "score", joinColumns = @JoinColumn(name = "stuId", referencedColumnName = "stuId"), inverseJoinColumns = @JoinColumn(name = "courseId", referencedColumnName = "courseId")) public Set<Course> getCourses() { return courses; }这里使用 CascadeType.ALL。来一段测试实例,删除刚才添加的 HibernateTemplate 同学。他会说我好悲惨,才进来没有多久。HibernateTemplate<Student> hibernateTemplate = new HibernateTemplate<Student>(); hibernateTemplate.template(new Notify<Student>() { @Override public Student action(Session session) { // 查询学生 Student student =(Student)session.get(Student.class, new Integer(23)); session.delete(student); return null; } });无惊无喜,一切按照预先的设想进行。删除学生时,中间表中与此学生有关联的信息,也就是说此学生选修的课程信息也自动被删除了。但是,会有一个想法,如果删除课程,则中间表中记录的与此课程有关的信息是否会自动删除呢?OK!开始行动之前,可别忘记在课程类中打开级联操作选项:嘿嘿!现在两边的级联操作功能都已经打开。private Set<Student> students=new HashSet<Student>(); @ManyToMany(targetEntity = Student.class, mappedBy = "courses",cascade=CascadeType.ALL) public Set<Student> getStudents() { return students; }打开后,执行删除 C 课程的实例,谁让 C 不好学了。HibernateTemplate<Course> hibernateTemplate = new HibernateTemplate<Course>(); hibernateTemplate.template(new Notify<Course>() { @Override public Course action(Session session) { // 查询学生 Course course =(Course)session.get(Course.class, new Integer(2)); session.delete(course); return null; } });这只是一个很简单的代码,但是却发生如雪崩一样的事件。到底发生了什么事情?大家进入 MySql 看看就知道了。3张表中空空如也,所有数据都没有了。就如同前面讲解一对多的级联删除一样。同样适用于多对多关联映射之中。因两边都已经打开了级联,删除操作如同无法控制的坏情绪,删除课程时,以中间表为连接,反复来往于三张表,把相关信息全部删除。所以,使用级联时一定要小心,否则,小心脏真的有点受不了。
- 2.5 级联操作 Hibernate 提供的级联操作带来了很多方便。但是,特别是在双向关联映射的情况下,不要把两边的级联操作全部打开,否则会把不该删除的数据删除掉。测试数据被级联删除倒无所谓,真实数据被删除了,可能就欲哭无门。
- 3. 二级缓存 MyBatis 二级缓存默认关闭,我们可以通过简单的设置来开启二级缓存。二级缓存的有效范围为一个 SqlSessionFactory 生命周期,绝大多数情况下,应用都会只有一个 SqlSessionFactory,因此我们可以把二级缓存理解为全局缓存。
- 4. 一对多关联映射中的级联操作 什么是级联操作?关系型数据库中由主外键维系的两张表,具有主从关系。如学生表和班级表,班级班是主表,学生表是从表。类似于删除某一个班级的信息,则需要先删除所在班的学生信息,再删除班级信息,这个操作就是级联操作。所谓级联操作,指操作一张表时,是否会牵连到与之有关联的其它表。现在,咱们是使用 Hibernate 进行数据操作,不可能还要劳驾自己亲力亲为吧。只需要做些简单配置,就可以让 Hibernate 自动做级联操作。进入班级类,修改代码如下:@OneToMany(targetEntity=Student.class,mappedBy="classRoom",cascade=CascadeType.REMOVE) public Set<Student> getStudents() { return students; }很简单,只需要使用 @OneToMany 的 cascade 属性,就能让 Hibernate 明白如何做级联操作。默认情况下,没有级联效应。cascade 是一个枚举类型:public enum CascadeType { ALL, PERSIST, MERGE, REMOVE, REFRESH, DETACH}ALL: 级联所有操作;PERSIST: 级联新增;MERGE: 级联更新或者新增;REMOVE: 级联删除;REFRESH: 级联刷新;DETACH: 级联分离。测试删除班级实例:HibernateTemplate<ClassRoom> hibernateTemplate = new HibernateTemplate<ClassRoom>(); hibernateTemplate.template(new Notify<ClassRoom>() { @Override public ClassRoom action(Session session) { ClassRoom classRoom=(ClassRoom)session.get(ClassRoom.class, new Integer(1)); session.delete(classRoom); return null; } });如果不添加 cascade 相关说明,因为有学生引用班级信息,班级信息是不能被删除的。添加后再测试,查看表中内容:班级以及班级所在学生信息全部删除!删除班级时能级联删除学生,反过来,删除学生能删除班级吗?想法很好,实践是检验真理的唯一手段,学生类中修改成如下代码:@ManyToOne(targetEntity=ClassRoom.class,cascade=CascadeType.REMOVE) @JoinColumn(name="classRoomId") public ClassRoom getClassRoom() { return classRoom; }测试实例:HibernateTemplate<Student> hibernateTemplate = new HibernateTemplate<Student>(); hibernateTemplate.template(new Notify<Student>() { @Override public Student action(Session session) { Student stu=(Student)session.get(Student.class, new Integer(2)); session.delete(stu); return stu; } });结果很残酷!学生被删除了,班级也被删除了!级联级联,只要设置了级联,不管删除学生还是班级,只要在对应表中有引用关系的数据就会被删除。现在,学生类、班级类中的级联删除都打开了。如果对下面情形的数据(编号 1、2 的学生的班级编号都为 1)进行删除操作,则会发生什么事情?数据库中的数据如下:测试删除编号为 1 的学生:HibernateTemplate<Student> hibernateTemplate = new HibernateTemplate<Student>(); hibernateTemplate.template(new Notify<Student>() { @Override public Student action(Session session) { Student stu=(Student)session.get(Student.class, new Integer(1)); session.delete(stu); return stu; } });进入 MySql,查看一下:天呀!这是级联还是株连呀,太让人后怕,数据都没有了。删除学生时,会级联删除和学生有关的班级,班级删除时,又会查看学生表中是否还存在与班级有关联的学生,有,则一刀下去,连根拔起。Hibernate 有点刹不住车,产生了级联连锁反应。针对上面的测试,如果班级表的级联关闭,执行测试代码,请问结果又会怎样?本节课程,讲解了级联删除,级联添加的内容留到下节课继续展开。
- jQuery jQuery is a fast, small, and feature-rich JavaScript library. It makes things like HTML document traversal and manipulation, event handling, animation, and Ajax much simpler with an easy-to-use API that works across a multitude of browsers. With a combination of versatility and extensibility, jQuery has changed the way that millions of people write JavaScript.(jQuery 官方介绍)
jquery省市二级联动相关搜索
-
j2ee
j2ee是什么
jar格式
java
java api
java applet
java c
java jdk
java list
java map
java script
java se
java socket
java swing
java switch
java web
java xml
java 程序设计
java 多线程
java 环境变量