zoukankan      html  css  js  c++  java
  • jQuery

    1. 什么是jQuery
    它是一个轻量级的javascript类库

    注1:就一个类“jQuery”,简写“$”

    2. jQuery优点
    2.1 总是面向集合
    2.2 多行操作集于一行

    3.如何使用jQuery(hello jQuery)
    3.1 导入js库
    <script type="text/javascript" src="js库路径"></script>

    <script type="text/javascript" src="${pageContext.request.contextPath }/js/jquery-3.3.1.js"></script>
    

      

    $(fn)、$(document).ready(fn)与window.onload的区别

         window.onload=function(){
    	     alert("3")
         }
         $(document).ready(function(){
        	 alert("2")
         })
         $(function(){
        	 alert("1");
         })
     /*
      *结论:$(fn)、$(document).ready(fn)是等价的。那个代码在前面哪个先执行。
      *jsp的dom树结构加载完毕即刻调用方法
      *window.onload最后执行
      *jsp的dom树加载完,css,js等静态资源加载完毕执行
      */
         
    

      

    4.jQuery三种工厂方法
    4.1 jQuery(exp[,context])
    exp:选择器

    context:上下文 容器/环境 默认:document

    /* 4.jQuery三种工厂方法
    	   4.1 jQuery(exp[,context])
    		exp:选择器
    		c */ontext:上下文	容器/环境  默认:document
    	//利用a标签获取jquery实例
    	//元素选择器
    	/* $("a").click(function(){
    		alert("被翻牌子了");
    	}); */
    	//利用ID=a3标签获取jquery实例
    		//ID选择器
    	/* $("#a3").click(function(){
    		alert("被翻牌子了");
    	}); */
    	//类选择器
    	/* $(".c1").click(function(){
    		alert("被翻牌子了");
    	}); */
    	//包含选择器(E1 E2)
    	/* $("p a").click(function(){
    		alert("被翻牌子了");
    	}); */
    	//组合选择器(E1,E2)
    	/* $("a,span").click(function(){
    		alert("被翻牌子了");
    	}); */
    	//讲解第二个参数的作用(在DIV标签内部寻找到a标签,然后给找到的标签添加事件)
    	//如果第二个参数没有填写,那么默认是document
    	//属性选择器
    	$("a","div").click(function(){
    		alert("被翻牌子了");
    	});
    })
    </script>
    </head>
    <body>
    	<p>
    		<a id="a1" class="c1" href="#">点我1</a>
    	</p>
    	<p>
    		<a id="a2" class="c2" href="#">点我2</a>
    	</p>
    	<p>
    		<a id="a3" class="c3" href="#">点我3</a>
    	</p>
    	<div>
    		<a id="a4" class="c1" href="#">点我4</a>
    	</div>
    	<div>
    		<p>
    			<a id="a5" class="c1" href="#">点我5</a>
    		</p>
    	</div>
        <span>点我</span>
        
    </body>
    

      

    jQuery.fn.extend()就是扩展jQuery本身的实例方法 “对象名.方法名”
    jQuery.extend()就是扩展jQuery本身的类方法。静态方法 “类名.静态方法名”

    2.JSON的三种方式

    2.1 对象
    {sid:'p001',sname:'zhangsan'}

    2.2 列表/数组
    [1,3,4,5]
    [{},{},{}]
    $.each(数组,function(idx,elem){

    });

    2.3 混合模式
    {id:3,num:[1,3,4,5]}
    {total:81,page:1,list:[{对象},{对象},{对象}]}

    2.4 JSON转换
    将字符串转成json对象: JSON.parse()
    将对象、数组转换成字符串:JSON.stringify()
    var obj={id:’001’:name:’zhangsan’

    $(function() {
    
    		var obj={sid:'001',snaem:'zs'};
    		console.log(obj);
    		//1.将对象.数组转化成字符串JSON.stringify();
    		var tostr=JSON.stringify(obj);
    		console.log(tostr);
    		
    		//2将字符串转化成JSON对象
    		var toobj=JSON.parse(tostr);
    		console.log(toobj); 
    
    		//.$.extend和$.fn.extend
    		//1.1$.extend(obj1,obj2,obj3[,...])
    		//将所有参数合并到obj1,并返回obj1;
    		var obj1={'pid':'001','pname':'李四'};
    		var obj2={'pid':'007'};
    		var obj3={'card':'43101010001'};
    		console.log(obj1.pid+','+obj1.pname+','+obj1.card);
    		$.extend(obj1,obj2);
    		console.log(obj1.pid+','+obj1.pname+','+obj1.card);
    		$.extend(obj1,obj2,obj3);
    		console.log(obj1.pid+','+obj1.pname+','+obj1.card);
    		
    		console.log("obj2:"+JSON.stringify(obj2)); 
    		
    		 //以obj参数扩展Jquery类方法和类属性(静态方法和静态属性)
    		//$.extend(obj):一次能扩展多个类方法
    		//$.method=function(option){};一次只能扩展一个类方法
    		  var obj = {
    			add : function(a, b) {
    				return a + b;
    			},
    			minus : function(a, b) {
    				return a - b;
    			}
    
    		}
    		 
    		 
    		 $.extend(obj); 
    		
    		var res=$.add(4,6);
    		console.log(res);
    		
    		var ues=$.minus(8,4);
    		console.log(ues);
    
    		//$.method=function(option){};一次只能扩展一个类方法
    		$.div=function(a,b){
    			return a*b;
    		};
    		
    		var res=$.div(2,2);
    		console.log(res); 
    		
    		//$.fn.extend:扩展jquery对象的实例方法
    		//实例化对象名.方法名
    		
    		 $.fn.extend({
    			color:function(){
    				return $(this).css({'background':'red'});
    			}
    		});
    		
    		$('div').color();
    		
    		$('table').bgcolor();
    		
    		
    	}); 
    

      

      

    1.1 什么是Jackson
    Jackson是一个简单基于Java应用库,Jackson可以轻松的将Java对象转换成json对象和xml文档,同样也可以将json、xml转换成Java对象。

    1.2 核心代码
    //JSON操作的核心,Jackson的所有JSON操作都是在ObjectMapper中实现

    对象User

    package com.demo;
    
    public class User {
    private int age;
    private String name;
    private int id;
    public int getAge() {
    	return age;
    }
    public void setAge(int age) {
    	this.age = age;
    }
    public String getName() {
    	return name;
    }
    public void setName(String name) {
    	this.name = name;
    }
    public int getId() {
    	return id;
    }
    public void setId(int id) {
    	this.id = id;
    }
    public User(int age, String name, int id) {
    	super();
    	this.age = age;
    	this.name = name;
    	this.id = id;
    }
    
    
    }
    

      

    //JSON操作的核心,Jackson的所有JSON操作都是在
       ObjectMapper mapper=new ObjectMapper();
      // 1.3.1 JavaBean、Map集合与JSON互转
      //	1)JavaBean/Map转JSONs
       //  2)JavaBean转json对象
          User user=new User(1, "lisji", 4);
          String objtojson=mapper.writeValueAsString(user);
          System.out.println(objtojson);
          
         //1.2map集合转化成json对象
         Map<String, Object> map=new HashMap<String, Object>();
         map.put("pid", "p001");
         map.put("pname", "zhangs");
         map.put("page", "18");
         String maptojson=mapper.writeValueAsString(map);
         System.out.println(maptojson);
         
         //1.3json对象转化成javabean对象
         String jsonStr="{"pname":"zhangs","pid":"p001","page":"18"}";
         User  us=mapper.readValue(jsonStr, User.class);
        // System.out.println(us);
       
         //1.4JSON对象转化成map集合
         //TypeReference(json对象序列化与反序列化)
         Map<String, Object> jsonTMap= mapper.readValue(jsonStr, new TypeReference<Map<String, Object>>() {
         });
       //System.out.println(jsonTMap);
       
    

      

    4.插件:表格行颜色切换效果

    新建bgcolor.css文件

    .head{
    	background: #ccc;
    }
    .over{
    	background: red;
    }
    .out{
    	background: #fff;
    }
    

     创建js文件jquery.bgcolor.js

    $.fn.extend({
    	bgcolor:function(options){
    		//判空处理
    		options=options||{};
    		var defaults={
    				headClass:'head',
    				overClass:'over',
    				outClass:'out'
    		};
    		//扩展jquery本身的类方法,命名参数写发
    		$.extend(defaults,options);
    		
    		return $(this).each(function(){
    			//修改表头的颜色
    			$("tr:eq(0)",this).addClass(defaults.headClass);
    			//添加行的悬停效果
    			$("tr:gt(0)",this).addClass(defaults.outClass).hover(function(){
    				$(this).removeClass(defaults.outClass).addClass(defaults.overClass);
    			},function(){
    				$(this).removeClass(defaults.overClass).addClass(defaults.outClass);
    			});
    		});
    			
    	}
    	
    })
    

      引入插件

    <script type="text/javascript" src="js/plugins/bgcolor/jquery.bgcolor.js"></script>
    <link rel="stylesheet" type="text/css" href="js/plugins/bgcolor/bgcolor.css">

      效果


    2.2 jQuery之Ajax实现省市县级联动(数据库版)

    $(function(){
    	query($("#prov"),7459)
    	$("#prov").change(function(){
    		query($("#city"),$(this).val())
    	});
    	$("#city").change(function(){
    		query($("#town"),$(this).val())
    	})
    	$("#prov").change(function(){
    		query($("#town"),$(this).val())
    	})
    	
    });
    function query(obj,pid){
    	$.ajax({
    		url:'RegionAction',
    	   data:{"parent_id":pid},
    	   dataType:'json',
    	   type:'post',
    	   success:function(data){
    		  obj.find("option:not(:first)").remove();
    		   $.each(data,function(idx,elem){
    			  obj.append("<option value='"+elem.id+"'>"+elem.region_name+"</option>")
    		   });
    	   }
    	   
    	});
    }
    
    </script>
    </head>
    <body>
    <select id="prov">
    <option value="">请选择</option>
    </select>
    <select id="city">
    <option value="">请选择</option>
    </select>
    <select id="town">
    <option value="">请选择</option>
    </select>
    

      效果

  • 相关阅读:
    mkconfig文件里的"cat << EOF >> config.h"
    (ARM v7)信号量、互斥体代码追踪
    (ARM v7)自旋锁、读写锁、顺序锁代码追踪
    mac 系统上安装navicat
    git2consul配置管理工具使用教程
    Spring Cloud Feign如何上传文件
    spring-cloud feign的多参数传递方案
    Consul下载安装及运行教程
    比SecureCRT更好用的工具MobaXterm下载安装使用教程
    Linux下RocketMQ下载安装教程
  • 原文地址:https://www.cnblogs.com/xmf3628/p/11094151.html
Copyright © 2011-2022 走看看