js 开启新窗口

$(function() {
        $("#btn").click(function() {
            var a = $("<a href='http://www.xxxx.com' target='_blank'>Apple</a>").get(0);
            
            var e = document.createEvent('MouseEvents');
 
            e.initEvent('click', true, true);
            a.dispatchEvent(e);
            #console.log('event has been changed');
        });
    });

 

js 确认删除原生弹框

if (confirm("是否确认删除")) {
				console.log(1111)
			}else{
				console.log(2222)
			}

 

 

 

js 或者jq 获取页面元素失效

举个例子,在页面上看到了ul  里面有三个li  在页面加载完成以后 就$('ul').find('li') 怎么也获取不到元素,

后来想到,有可能li 也是动态加载的,页面原有的js 还没把li 加载好,我就去获取了,肯定获取不到,然后我就

setTimeout(function(){

$('ul').find('li');

},3000);

加了一个延时,结果就能正常获取了。第一次遇到这种情况,踩坑踩了一个多小时

 

jq 控制checkbox 切换选中状态失效

$(".chooseall").click(function(){
    if($(".chooseall").prop("checked") == true){
        $("input[name='checkbox1']").prop("checked", false);
        console.log(1);
    }else{
        $("input[name='checkbox1']").prop("checked", true);
        console.log(2);
    }
});

jquery 1.6以上 prop 和attr 的操作对象不同,attr是操作html节点  prop操作的是js获取的DOM对象

详情参考:脚本之家

 

jq当前元素的点击事件

 

 

<input onclick=shoucang(this) value='666'>

function shoucang(data){

console.log( $(data).val() );

}

 

 

 

 

ajax 上传图片

$('#receiptimg').change(function(event) {
	var formData = new FormData();
	var id =$('#id').val();
    	formData.append("file", $(this).get(0).files[0]); 
        //文件 因为我是点击按钮选择了文件就自动上传 所以是this 如果是点击按钮提交就看下面的
    	
        formData.append("id", id); //额外参数
    	 $.ajax({
                  url:yourUrl,
	          type:'POST',
	          data:formData,
	          cache: false,
	          contentType: false, //必须要有   
	          processData: false, //必须要有   
	          success:function(data){
	              //code
	          },
	          error:function(data){
	            //code
	           }
	             
	      });
	});



//下面是百度的一段代码

<p>姓名<input type="text" name="username"></p>
<p>头像<input type="file" id="upload"></p>
<p><button class="btnnn">提交</button><span class="tishi"></span></p>

$(".btnnn").click(function () {
        var formData=new FormData();
        formData.append("username",$(":text").val());
        formData.append("file",$("#upload")[0].files[0]);  //这里就是点击按钮 所以是根据按钮的id找  
        $.ajax({
            url:"xxxx",
            type:"POST",
            data:formData,
            contentType:false,
            processData:false,
            success:function (data) {
              //code
            }

        })
    })

2018-4-26

 

 

 

 

 

新增、删除属性

 

$("#id").addClass('classname')

$("#id").removeClass('classname')

 

 

获取值,得到值,修改值,清空值

 

 

$("#input").val()

获取img标签的src  并且赋值

获取:$("#code_img").attr('src'); 或者 $("#code_img").prop('src');

var newsrc = $("#code_img").attr('src')+'?time='+Math.random()

赋值: $("#code_img").attr('src','xxxxxxxxxx');  或者 $("#code_img").prop('src','xxxxxxxx');

判断多选框是否被选中:

if($('input[type="checkbox"]').prop("checked")==true){
     //do something
  }

 

 

获取自定义属性

 

 

 

$('#code').getAttribute('mylink')

 

 

 

事件

.click,onclick()

click 与onclick的区别:

$(function(){
$("#btn3").click(function(){
alert("second");
});
});

function change(){
alert("first");
}

然后点击:
<button id="btn3"οnclick="change()">dd</button>
先弹出first,然后再弹出second

 

 

 

 

 

数据转化成对象

json_encode的数据到模板里用js先 eval()转换成对象

ajax获取的html字符串,用$(data)即可转化成对象  $(data).html 即可获取data里面的html内容

 

 

ajax局部刷新页面js失效

比如按钮的click事件,绑定事件用 on    因为局部刷新以后事件要重新绑定,用on 即可  具体的参数请自行百度

 

$('#id').on('click', function() {      
   	// function code		
});

Jq追加了一个按钮,需要绑定点击事件,这个时候用on来绑定,但是要先选择父级

//先往div里追加一个button id='button'
//绑定点击事件
$('#div').on('click','#button',function(){
//这里需要先选择 button的父级 然给button绑定
})

$('#button').on('click',function(){
//如果这样直接绑定,经常是无效的,不知道为什么 = =
})

2018年5月28日16:15:54

 

 

JS序列化表单 中文乱码

 

var form = $('#add_menu_form').serialize(); // 表单里有中文 serialize()自动调用了encodeURIComponent方法将数据编码了
 var data = decodeURIComponent(form,true); // 解码中文
  console.log(data);

php接收到数据后  直接 parse_str()处理一下就好  

2018年6月4日

 

遍历

 

$('#id').each(function(){

alert($(this).text())

})  //进行DOM遍历,比如遍历一个ul 显示里面的li的文本内容

 

 

$.each(data,function(key,val){

alert(val.属性名)

})

//遍历数据,比如json对象,应该alert(val.属性名)

 

 

 

 

 

给单选按钮追加选中

 

if (if_show) {
$("input:radio[name='if_show']").eq(0).attr("checked",'checked');
}else{
$("input:radio[name='if_show']").eq(1).attr("checked",'checked');
}

 

定时器

//定时器,2秒钟后触发按钮的点击事件
setTimeout(function (){
$('#button').click();
$('#showmessage').trigger("click");
},2000);

 

给select 下拉列表追加默认选中

 

 

$("select[name='xxx']").find("option[value='"+pid+"']").attr("selected",true);//pid 是变量,这里拼接一下
$("#id").find("option[text='xxx']").prop("selected",true);//attr 也可以

 

 

var options=$(“#id option:selected”); //获取选中的项这个对象

alert(options.val()); //拿到选中项的值

alert(options.text()); //拿到选中项的文本

 

 

 

 

 

js调用函数的返回值取不到的问题:

简单的例子:

function check_name(){
	var ck_res=false; //定义一个变量
	$.ajax({
	type:'get',
	async:false,
	success:function(msg){
	if(msg){ 
	ck_res = true;   //更改变量值
	}else{
	ck_res = false; //更改变量值
	}
	}
	});
	return ck_res; //返回变量值
	}

var res = check_name() 这个时候res的值就是 函数的返回值
function check_name(){
	
	$.ajax({
	 type:'get',
	 async:false,
	 success:function(msg){
	  if(msg){ 
	  return true;
	  }else{
	  return false;
	  }
	 }
	});
	}
var res = check_name() 这个时候 res就是未定义

因为是ajax返回了以后并没有变量接收,返回值只是存在于check_name函数内部,如果 var ajax_return=$.ajax({......}) 这样 ajax_return就是一个对象,然后在check_name()里再把这个对象return,最后res有值,不过也是个对象,里面的responseText是文本内容,不推荐这种写法,只是说明为什么在ajax里直接return 然后再调用函数却接收不到值 。第一种在方法里先声明变量,在ajax里改变以后,在方法里再return 变量 这种才是常规的写法。

 

Jquery判断元素是否隐藏

 

if($("#test").is(":hidden")){
       $("#test").show();    //如果元素为隐藏,则将它显现
}else{
      $("#test").hide();     //如果元素为显现,则将其隐藏
}