首页 > 其他分享 >HTMLDOM中innerHTML和样式控制

HTMLDOM中innerHTML和样式控制

时间:2022-11-23 18:33:42浏览次数:52  
标签:样式 HTMLDOM getElementById let innerHTML table document div1

HTMLDOM_innerHTML

标签体的设置和获取:innerHTML

innerHTML 属性可用于获取或替换 HTML 元素的内容。

innerHTML 属性可用于获取或改变任何 HTML 元素,包括 <html> 和 <body>

<head>
    <meta charset="UTF-8">
    <title>HTMLDOM</title>
    
</head>
<body>
    
    <div id="div1">
        齐浩寒大傻蛋
    </div>

<script>

    let div1 = document.getElementById("div1");
    let innerHTML = div1.innerHTML;//获取标签体内容
    // alert(innerHTML);
    //div标签中替换一个文本输入框
    // div1.innerHTML = "<input type='text'>";
    //div标签中追加一个文本框
    div1.innerHTML += "<input type='text'>";

</script>
</body>

简化动态表格案例:

<head>
    <meta charset="UTF-8">
    <title>动态表格添加</title>
    <style>
        table{
            border: 1px solid;
            margin: auto;/* 外边距居中 */
            width: 500px;
        }
        td,th{
            text-align: center;/* 文字居中 */
            border: 1px solid;
        }
        div{
            text-align: center;
            margin: 50px;

        }
    </style>
</head>
<body>

    <div>
        <input id="id" type="text" placeholder="请输入编号">
        <input id="name" type="text" placeholder="请输入姓名">
        <input id="gender" type="text" placeholder="请输入性别">
        <input id="btn_add" type="button" value="添加">
    </div>

    <table>
        <caption>学生信息表</caption><!-- 标题 -->
        <tr>
            <!-- 表头 -->
            <th>编号</th>
            <th>姓名</th>
            <th>性别</th>
            <th>操作</th>
        </tr>

        <tr>
            <!-- 身体 -->
            <td>1</td>
            <td>齐</td>
            <td>男</td>
            <td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td>
        </tr>
        <tr>
            <td>2</td>
            <td>浩</td>
            <td>男</td>
            <td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td>
        </tr>
        <tr>
            <td>3</td>
            <td>寒</td>
            <td>?</td>
            <td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td>
        </tr>
    </table>

<script>
    /*
        分析:
            1,添加
                1.给添加按钮绑定事件
                2.获取文本框内容
                3.创建td设置td的文本框的内容
                4.创建tr
                5.将td添加到tr中
                6.获取table,将tr添加到table中
            2,删除
                1.确定点击的是哪一个超链接
                    <td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td>
                2.怎么删除
                    removeChild():通过父节点删除子节点


     */
    /*
       使用innerHTML来实现追加效果
     */
    //1获取按钮
    document.getElementById("btn_add").onclick = function () {
        //2获取文本框的内容
        let id = document.getElementById("id").value;
        let name = document.getElementById("name").value;
        let gender = document.getElementById("gender").value;

        //获取table
        let table = document.getElementsByTagName("table")[0];

        table.innerHTML += "        <tr>\n" +
            "            <td>"+id+"</td>\n" +
            "            <td>"+name+"</td>\n" +
            "            <td>"+gender+"</td>\n" +
            "            <td><a href=\"javascript:void(0);\" onclick=\"delTr(this);\">删除</a></td>\n" +
            "        </tr>";
    }



    //删除方法
    function delTr(obj){
        var table = obj.parentNode.parentNode.parentNode;
        var tr = obj.parentNode.parentNode;

        table.removeChild(tr);
    }
</script>
</body>

 

 

 

HTMLDOM_样式控制

使用html元素对象的属性

控制元素样式

  1.使用元素的style属性来设置

<script>
    //获取id
    let div1 = document.getElementById("div1");
    //绑定点击事件
    div1.onclick = function (){
        //修改样式方式一
        div1.style.border = "1px solid red";

        div1.style.width = "200px";

        //font-size-->fontSize
        div1.style.fontSize = "20px";
    }
</script>

  

  2.提前定义好类选择器的样式,通过元素的className属性来设置器class属性值

<head>
    <meta charset="UTF-8">
    <title>控制样式</title>
    <style>
        .d1{
            border: 1px solid red;
            width: 100px;
            height: 100px;
        }
        .d2{
            border: 1px solid blue;
            width: 200px;
            height: 200px;
        }
    </style>
</head>
<body>
    <div id="div2">
        div
    </div>


<script>    let div2 = document.getElementById("div2");
    div2.onclick = function (){
        //设置属性值 样式为d2
        div2.className = "d2";
    }

</script>
</body>

 

标签:样式,HTMLDOM,getElementById,let,innerHTML,table,document,div1
From: https://www.cnblogs.com/qihaokuan/p/16919402.html

相关文章

  • [WordPress] 主题美化 樱花背景+灯笼特效+鼠标样式 [持续更新]
    樱花背景黑白主题适配//樱花背景特效<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"......
  • 【WinForm】使用选择文件的窗口样式选择文件夹
    使用选择文件的窗口样式选择文件夹零、需求传统的选择文件夹的方式太小了,不好操作,不过选择文件的方式倒是挺不错的,能不能把选择文件夹的方式改为选择文件这种样式呢?选......
  • HTML-样式
    1 style属性用于改变HTML元素的样式。<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>Lightly-HTML-Project</title><......
  • MAUI新生1.6-XAML语法基础:样式风格Style&Settter
    一、样式的定义和使用Style类似于前端的CSS,可以对视觉元素的样式进行有组织的管理,大量减少代码和重复工作量。Style需要结合资源字典使用,将Style定义在资源字典中,元素通过......
  • css样式文字和数字不在一行,数字会自动换行到下一行
    一个div里面文字后面的数字会自动换行style="overflowWrap:break-word;word-break:break-all;"加上word-break:break-all就会显示在一排了......
  • css预处理和样式重置
    scss的安装和使用:1.安装:cnpmisass-loader@7node-sass@4-S2.使用:less的安装和使用:1.安装:cnpmiless@3less-loader@7-S2.使用:运行:npmrunserve/devyarn......
  • Vue笔记 - 样式穿透原理及使用方法
    样式穿透目录样式穿透1.为什么需要样式穿透1.1为什么样式会失效2.如何使用样式穿透2.1实例1.为什么需要样式穿透在开发中引入了第三方组件库(如element-ui),但又想......
  • vue 样式穿透和scoped
    vue样式穿透style节点的scoped属性是为了防止组件之间的样式冲突,实现样式模块私有化,避免全局样式污染对于style上加了scope属性的组件,会主动加上data-v-xx的属......
  • elementUI tree树节点文字超出时省略或折行 样式
    文字超出时折行::v-deep.tree{width:100%;.el-tree-node{white-space:normal;.el-tree-node__content{height:100%;a......
  • 【快应用】父组件中如何设置子组件样式
    问题背景:子组件被引用时,如果在父组件的布局效果不理想,需要去修改子组件对应的样式,是比较麻烦的,现在快应用在1100版本之后推出了externalClasses属性,可以将外部样式直接传给......