day3 操作各种属性和样式

一个节点对象初始就有很多属性和方法,这些属性和方法是JavaScript原本就赋予给这个对象的,我们要做的就是操作这些属性或者方法,那操作就分读取


一.JavaScript标签属性

标签属性是我们学过的一些标签属性 id class name type等等的

1.标签属性(合法标签属性)   id class name...

    1.操作方式通过链式 点操作

        <div id="wrap" class="content"></div>

        <script>

                let oDiv = document.getElementsByTagName("div")[0]

                oDiv.id = "list" //更改元素的ID名

        </script>

       2.特殊属性 class  操作的时候是 className

                  src属性不能拿来做判断

                   color不能做判断

            <div id="wrap" class="content"></div>

            <img src=""></img>

            <script>

                    let oDiv = document.getElementsByTagName("div")[0]

                    oDiv.className = "list" //更改元素的class类名

                    let oImg = document.getElementsByTagName("img")[0]

                    console.log(oImg.src)//我们添加的是一个相对路径,打印的却是一个绝对路径

            </script>

        3.变量被赋值这个对象节点之后,这个节点对象其他属性发生改变,这个变量还是代表这个获取的对象

            <div id="wrap" class="content"></div>

            <script>

                    let oWrap = document.getElementById("wrap")

                    oWrap.className = "list" //更改元素的class类名

                    oWrap.innerHTML = 123

                    let aContent = document.getElementsByClassName("content")

                    aContent.id = "text"

                    aContent.innerHTML = 456

            </script>

        4.变量被赋值这个对象节点之后,这个节点对象此属性发生改变

      (1)静态获取  getElementById      querySelector       querySerletorAll

            改变此对象属性值之后,获取该对象的变量依然可以使用,不会因为改变赋值对象节点对应属性而无法使用

            <div id="wrap" class="content"></div>

            <script>

                    let oWrap = document.getElementById("wrap")

                    oWrap.id = "list"

                    oWrap.innerHTML = 123

            </script>

      (2)动态获取 getElementsByClassName     getElementsByTagName       getElementsByName

            改变此对象属性值之后,获取该对象的变量不可以使用,因为改变赋值对象节点对应属性而无法使用

        <div id="wrap" class="content"></div>

        <script>

                let oContent = document.getElementsByClassName("content")[0]

                oWrap.className = "text"

                oWrap.innerHTML = 123//不会生效

        </script>

动态获取解决办法:

        转换地址  单独处理放在一个变量中

        <ul>

            <li class="list"></li>

            <li class="list"></li>

        </ul>

        <script>

               let aList = document.getElementsByClassName("list")

                let x = aList[0]

                aList[0].className = "text"

                aList[0].innerHTML = 123

                x.innerHTML = 456

        </script>

2.标签自定义属性(不合法属性)

标签不具有的属性,程序员人为添加的属性

<div id="wrap" class="content" marray="no"></div>

<script>

        let oContent = document.getElementsByClassName("content")[0]

        oContent.age = "18"

        console.log(oContent.marray) //undefind

</script>

(1)添加自定义属性 setAttribute("属性名","值")

<div id="wrap" class="content"></div>

<script>

        let oContent = document.getElementsByClassName("content")[0]

        oContent.setAttribute("age",18)

</script>

(2)得到自定义属性 getAttribute("属性名")

<div id="wrap" class="content" marray="no"></div>

<script>

        let oContent = document.getElementsByClassName("content")[0]

        console.log(oContent.getAttribute("marray"))

</script>

(3)移除属性名 removeAttribute("属性名")

<div id="wrap" class="content" marray="no"></div>

<script>

        let oContent = document.getElementsByClassName("content")[0]

        oContent.removeAttribute("marray")

</script>


二、JavaScript对象属性

对象属性是我们JavaScript内置的一些属性,像我们的 innerHTML 各种事件等等

1.对象自带属性

    console.dir() 查看对象自带的js属性

<div></div>

<script>

        let oDiv = document.getLementsByTagName('div')[0]

        console.dir(oDiv)//查看对象自带的JS属性

</script>

2.对象自定义属性

    内置的JS对象上不具有的,我们自己添加的,通过console.dir也是能打印出来的

    对象.属性名 = 值

<div></div>

<script>

        let oDiv = document.getLementsByTagName('div')[0]

        oDiv.love = "dajia"

        console.dir(oDiv)//查看对象自带的JS属性

</script>


三.+号的初步认识

 +号

                1.数字相加还是数字(number)

                2.字符串相加叫拼接

                3.+=   X=X+1

                        X+=1

                4.变量在已经赋值使用时 不能加引号包裹(字符串)

                5.字符串和变量拼接 引号一定要前后配对 变量前后是加号作为分割点

            ES6:

                模板字符串

                    `内容${变量}内容`

    <style>

        #wrap{

            width: 100px;

            height: 100px;

            background-color:pink;

        }

    </style>

    <div id="wrap"></div>

    <script>

        let x = '1'

        let y = 2

        console.log(x+y)

        let oWrap = document.getElementById("wrap")

            oWrap.onclick = function() {

                //oWrap.innerHTML += 123

                //oWrap.innerHTML += "<p></p>"

                //oWrap.innerHTML += "<p>" + y + "</p>"

                //oWrap.innerHTML += "<p style= 'width:200px;background-color:red;'>" + y + "</p>"

                oWrap.innerHTML += `<p style= "width:200px;background-color:red;">${y}</p>`

            }

    </script>


四.css样式操作

1.改变元素样式方法外部样式 内部样式 行内样式

    外部样式:单纯的JS不能操作外部样式

    内部样式:JS可以操作HTML页面任何元素,可以操作style标签

    行内样式:JS操作元素样式最常用方法,标签的自带属性style 通过点操作 元素.style.css属性 = "属性值"

<div id="wrap">123</div>

<script>

            let oWrap = document.getElementById("wrap")

            oWrap.style.color = "red"//单个属性

            oWrap.style.cssText = "font-size:25px;font-weight:bold;"//多个属性

</script>

注意:

    1.分样式用驼峰写法

    <script>

            oWrap.backgroundColor = "blue"

    </script>

    2.个别样式有兼容以及保留字css属性

    <script>

            oWrap.style.cssFloat = "right"

    </script>

2.通过添加类名改变样式

可以在内部样式把css样式写好,通过添加类名的方式

   <style>

       #wrap{

            width: 100px;

            height: 100px;

            background-color:pink;

        }

    </style>

    <div id="wrap"></div>

    <script>

        // oWrap.onclick=function(){

        // oWrap.className="content"

        // }

==

        oWrap['onclick']=function(){

            oWrap.className="content"

        } 

    </script>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容