// 设置setAttribute('属性名', '属性值') // input_obj.checked = true; 添加选中效果// 获取getAttribute('属性名') // console.log(inputobj.checked); 查看属性值// 删除removeAttribute('属性名')
var div1 = document.getElementById('d1');div1.className; // 获取该标签拥有的类名div1.classList; // 获取该标签拥有的类名的数组div1.classList.add('c2'); // 添加类值div1.classList.remove('c3'); // 删除类值div1.classList.toggle('c3'); // 有就删除,没有就添加var t = setInterval("div1.classList.toggle('c3')",1000); //定时器添加
Document.getElementById(“head1”).style.color=red;
btn_all.onclick = function () { li_list = ul.children; // 获取的dom对象 for (let li of li_list) { console.log(li.firstChild); li.firstChild.checked = true; // js写法 // $(li.firstChild).prop('checked', true); // jquery写法:dom对象转化为jquery对象,然后通过prop设置属性 } };
// 两种形式: // 嵌套: <label >用户名: <input type="text" name="username" id="username"></label> // for-id捆绑,非嵌套 <label for="password">密码: </label> <input type="password" name="password" id="password">
<button type="submit" id="btn">注册</button>
// 普通按钮,没有提交效果<input type="button"><button type="button">注册</button>// 下面这两个能够提交form表单数据<input type="submit" value='登录'><button type="submit">注册</button>
// 外部网址引入 <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.js"></script>// 本地文件引入 <script src="jquery.js"></script> //jquery.js本地文件路径
// jquery对象 var d1 = $('#d1'); --> jQuery.fn.init?[div#d1] // 原生dom对象 var d = document.getElementById('d1'); --><div id='d1'></div>// jquery对象和dom对象之前不能调用互相的方法// 但jquery对象和dom对象可以 互相转换 d1[0] // jquery对象 --> dom对象 // d1.eq(0) 这种索引方式得到的就是jquery对象 $(d) // dom对象 --> jquery对象
$('#d1') -- 同css
$('.c1')
$('标签名称') -- $('span')
$('#d1,.c2')示例: html代码 <div id="d1"></div> <div class="c2"> 这是c2 </div> css代码: #d1,.c2{ background-color: red; height: 100px; width: 100px; border-bottom: 1px solid black; } jquery代码: $('#d1,.c2').css('background-color','green'); $('#d1,.c2')[1]; -- 索引为1的dom对象 $('#d1,.c2').eq(1); -- 索引为1 的jquery对象
原生dom对象.style.margin-left是不能用的,带-的要写成原生dom对象.style.marginLeft(驼峰体)
同时设置css的多个值时,以字典形式
// HTML代码:<form> <label>Name:</label> <input name="name" /> <div> <label>Newsletter:</label> <input name="newsletter" /> </div></form> <input name="none" />// jquery代码: $("form input")// 结果 $("form input").change(function () { var a = $(this).val(); console.log(a); });// 当改变前两个框时,都会打印框中输入的值;但最后一个框不会,因为它虽然也是input但它不在form内,不会被选择到。
// html代码: <div class="c1" xx="oo"> 这是啥! </div>// css代码: [xx]{color:red}input标签: type='xx' [type='xx']--对应的input标签$('[xx]').css('color','green');$('[xx="oo"]').css('color','pink');// 设置多个时,需要使用字典的形式。
:checked // 找到被选中的input标签:selected // 找被选中的select标签中的option标签:enabled // 输入操作中各类框的默认设置,input(可以输入)、radio、checkbox(可以进行点击选择)、select(可以点开进行选择):disabled // 使得输入操作中各类框都禁止被点击(变灰)。
$(":text") // 找到所有input标签// $(":input") 找到所有input标签// $(":password") 找到所有input且type=password的标签// $(":radio") 找到所有input且type=radio的标签// $(":checkbox") 找到所有input且type=checkbox的标签html代码: <form action=""> <input type="text" id="username"> <input type="text" id="username2"> <input type="password" id="pwd"> <input type="submit"> </form>jquery代码:找到所有的type=text的input标签 $(':text');
html代码 <ul> <li>谢一峰</li> <li class="c1">王子宇</li> <li>孙波</li> <li class="c2">石淦</li> <li> <span>白雪冰</span> </li> <li>方伯仁</li> </ul>
var c = $('.c1');c.parent();c.parents(); // 直系的祖先辈c.parentsUntil('body'); // 往上找,直到找到body标签为止,不包含body标签
var u = $('ul');u.children(); // 找到所有儿子标签u.children('.c1'); // 找到符合.c1选择器的儿子标签
var c = $('.c1');c.next();nextAll(); // 下面所有兄弟c.nextUntil('.c2'); // 下面到某个兄弟为止,不包含那个兄弟
var c = $('.c1');c.prev();c.prevAll();// 上面的所有兄弟,注意顺序是反的,从自己上一个到第一个c.prevUntil('.c1'); // 到上面某个兄弟为止,不包含那个兄弟,注意顺序都是反的
c.siblings(); // 找到不包含自己的所有兄弟c.siblings('.c1'); // 筛选兄弟中有class类值为c1的标签
$('li').find('span'); // 等同于css的li span选择器
$('li').first(); // 找所有li标签中的第一个$('li').last(); // 找所有li标签中的最后一个$('li').eq(0); // 按照索引取对应的那个标签,索引从0开始$('li').eq(-1); // 最后一个
本质:替换操作
同js的innerText和innerHTML
取文本: c.text(); 不带标签 c.html(); 带标签设置文本: c.text('文本'); c.html('文本'); -- 文本--"<a href=''>皇家赌场</a>"
// 获取属性值console.log($("ul li:eq(1)").attr("title"));// 设置属性$("ul li:eq(1)").attr("title","不吃橘子"); // 值还可以设置为函数 $("ul li:eq(1)").attr("title",function(){ return this.value});// 设置多个值$("ul li:eq(1)").attr({title:"不喝橘子汁",value:"不是123"});// 删除属性$("ul li:eq(1)").removeAttr ("title");
let text_list = $('.tips');text_list.eq(1).css({'color': 'red'});
比如一个id=a4的a标签$(this.getElementByXid("a4")).css({ 'border-color':'#FFFFFF #FFFFFF #2FA4E7 #FFFFFF', 'border-bottom-style':'solid', 'border-width':'0px 0px 2px 0px', 'color':'#2FA4E7', });
html代码 <div class="c1"> </div>css代码: .c1{ background-color: red; height: 100px; width: 100px; } .c2{ background-color: green; }jquery$('div').addClass('c2');$('div').removeClass('c2');$('div').toggleClass('c2');示例: var t = setInterval("$('div').toggleClass('c2');",500);
示例:html代码: <input type="text" id="username"> <input type="radio" class="a1" name="sex" value="1">男 <input type="radio" class="a1" name="sex" value="2">女 <input type="checkbox" class="a2" name="hobby" value="1">抽烟 <input type="checkbox" class="a2" name="hobby" value="2">喝酒 <input type="checkbox" class="a2" name="hobby" value="3">烫头 <select name="city" id="s1"> <option value="1">北京</option> <option value="2">上海</option> <option value="3">深圳</option> </select> <select name="lover" id="s2" multiple> <option value="1">波多</option> <option value="2">苍井</option> <option value="3">小泽</option> </select>
获取值: 文本输人框:$('#username').val(); 单选radio框:$('.a1:checked').val(); 多选checkout框:$('.a2:checked').val()是不行的;需要循环取值,如下: var d = $(':checkbox:checked'); for (var i=0;i<d.length;i++){ console.log(d.eq(i).val()); } 单选select框:$('#city').val(); 多选select框:$('#lover').val();// select的多选模式(multiple)虽然也是数组包裹的多个结果,但是查询结果时不需用for循环迭代输出,可以直接以数组形式输出。
设置值: 文本输入框:$('#username').val('you are my love'); 单选radio框:$('.a1').val(['2']); // 注意内容必须是列表(由val()输出形式决定),写的是value属性对应的值 多选checkout框:$('.a2').val(['2','3']) 单选select框:$('#city').val(['1']); 多选select框:$('#lover').val(['2','3'])
$('.c1').click(function () { //$(this)表示的就是它自己 $(this).css('background-color','green'); // $('.c1').css('background-color','green'); })