js补充、jquery

今日内容

js补充

标签属性操作

// 设置setAttribute('属性名', '属性值') // input_obj.checked = true; 添加选中效果// 获取getAttribute('属性名') // console.log(inputobj.checked); 查看属性值// 删除removeAttribute('属性名')

class类值操作

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); //定时器添加

css样式操作

Document.getElementById(“head1”).style.color=red;

js事件绑定

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设置属性 } };

HTML的label标签补充

  • 将 input 与 label 捆绑起来,让 html 知道你 input 的是什么数据
  • 有一种特效:点击输入框前的文字,可以跳转至框内。
// 两种形式: // 嵌套: <label >用户名: <input type="text" name="username" id="username"></label> // for-id捆绑,非嵌套 <label for="password">密码: </label> <input type="password" name="password" id="password">

button补充

  • <button type="submit" id="btn">注册</button>
  • 这个形式的button按钮放在form标签里可以当做input-submit使用
    • 可以跟后端做交互
    • 且,这种内嵌形式的标签可以放图片!
// 普通按钮,没有提交效果<input type="button"><button type="button">注册</button>// 下面这两个能够提交form表单数据<input type="submit" value='登录'><button type="submit">注册</button>

jQuery

jquery引入

// 外部网址引入 <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.js"></script>// 本地文件引入 <script src="jquery.js"></script> //jquery.js本地文件路径

jQuery初识

// 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对象
  • dom原生对象和jquery对象不能使用对方的方法
  • 两种代码可以混着使用,但对象、方法不能乱使用

选择器

id选择器

$('#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');// 设置多个时,需要使用字典的形式。

表单对象属性选择器disable

:checked // 找到被选中的input标签:selected // 找被选中的select标签中的option标签:enabled // 输入操作中各类框的默认设置,input(可以输入)、radio、checkbox(可以进行点击选择)、select(可以点开进行选择):disabled // 使得输入操作中各类框都禁止被点击(变灰)。

表单选择器type

$(":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>
parent()直系祖辈们
var c = $('.c1');c.parent();c.parents(); // 直系的祖先辈c.parentsUntil('body'); // 往上找,直到找到body标签为止,不包含body标签
children()亲儿子们
var u = $('ul');u.children(); // 找到所有儿子标签u.children('.c1'); // 找到符合.c1选择器的儿子标签
next() 下一个
var c = $('.c1');c.next();nextAll(); // 下面所有兄弟c.nextUntil('.c2'); // 下面到某个兄弟为止,不包含那个兄弟
prev()上一个
var c = $('.c1');c.prev();c.prevAll();// 上面的所有兄弟,注意顺序是反的,从自己上一个到第一个c.prevUntil('.c1'); // 到上面某个兄弟为止,不包含那个兄弟,注意顺序都是反的
siblings()同辈们
c.siblings(); // 找到不包含自己的所有兄弟c.siblings('.c1'); // 筛选兄弟中有class类值为c1的标签
find() 找后代
$('li').find('span'); // 等同于css的li span选择器
first()和last()和eq(索引值)
$('li').first(); // 找所有li标签中的第一个$('li').last(); // 找所有li标签中的最后一个$('li').eq(0); // 按照索引取对应的那个标签,索引从0开始$('li').eq(-1); // 最后一个 

text() 和 html()

  • 本质:替换操作

  • 同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");
  • 就这么简单, attr 其实就是原生js中 getAttribute 的简化实现, 而removeAttr 就是 removeAttribute 的简写了。
  • 使用 attr 对 checked 属性进行设置时,会出错,故 checked 属性就用 prop 设置就行

css值操作

  • 某些html标签可以通过id来获取并添加css效果,(格式就像json对象)如下。
  • 调用对象是jquery对象
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', });

class类值操作

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);

val值操作 ***

  • 示例:
示例: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'); })

相关文章