前端三件套(HTML + CSS + JS)

news2024/12/28 3:13:58

前言:

前端三件套,会用就行

毕竟在后面学习JavaWeb,以及在学习vue的时候也有帮助

前端三件套:

  • HTML 定义网页的结构和内容。
  • CSS 负责网页的样式和布局。
  • JavaScript 添加动态交互和功能。

使用到的工具是Visual Studio Code 即VSCode

下载地址:Download Visual Studio Code - Mac, Linux, Windows

下载安装后,使用到的插件:

1.场景变为简体中文:

2.自动补全、智能提示和语法高亮,有助于提高开发的效率

3.页面的预览

注意:

  • 想要在编写时,页面跟着标签的修改而实时变化,请打开自动保存
  • 点击左上角的三条杠,找到文件,点击自动保存

4.在修改指标签时,修改前面的,后面的也会相应变化

一、HTML

1. HTML(超文本标记语言)

作用:
HTML 是网页的结构语言,用于创建和组织网页内容。它通过标记(tags)来定义不同的元素,如标题、段落、链接、图像等。

特点:

  • 结构化内容: 使用标签(如 <h1><p><a>)来组织信息。
  • 无表现性: HTML 关注内容的结构,而不涉及样式或行为。
  • 可扩展性: 支持多种元素和属性,可以嵌套和组合。

2.常用标签的练习

1. 基本结构标签

  • <html>: 定义HTML文档的根元素。
  • <head>: 包含文档的元数据(例如标题、样式、脚本等)。
  • <title>: 定义文档的标题,通常显示在浏览器的标题栏。
  • <body>: 定义文档的主体,包含可见内容。

2. 文本格式化标签

  • <h1><h6>: 定义标题,<h1>为最大标题,<h6>为最小标题。
  • <p>: 定义段落。
  • <br>: 插入换行符。
  • <strong>: 使文本加粗,表示重要性。
  • <i>: 使文本倾斜,表示强调。
  • <u>: 下划线文本。

3. 列表标签

  • <ul>: 定义无序列表。
  • <ol>: 定义有序列表。
  • <li>: 列表项,用于<ul><ol>内。

在创建好的.html文件中输入!,再按Tab键,可自动生成一个模板

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>html的常用标签练习</title>
</head>
<body>
    <h1>一级标题标签</h1>
    <h2>二级标题标签</h2>
    <h3>三级标题标签</h3>
    <h4>四级标题标签</h4>
    <h5>五级标题标签</h5>
    <p>段落标签</p>
    <p><b>字体加粗</b>、<u>下划线</u>、<s>删除线</s>、<i>斜体</i>
    </p>

    <ul>
        <li>无序列表1</li>
        <li>无序列表2</li> 
        <li>无序列表3</li>
    </ul>

    <ol>
        <li>有序列表1</li>
        <li>有序列表2</li>
        <li>有序列表3</li>
    </ol>

   <table border ="1">
    <tr>
        <th>
            列名   列属性  列方法
        </th>
        <th>
            列名   列属性  列方法
        </th>
        <th>
            列名   列属性  列方法
        </th>
    </tr>
    <tr>
        <td>
            元素1  元素2   元素3
        </td>
        <td>
            元素1  元素2   元素3
        </td>
        <td>
            元素1  元素2   元素3
        </td>
    </tr>
    <tr>
        <td>
            元素1  元素2   元素3
        </td>
        <td>
            元素1  元素2   元素3
        </td>
        <td>
            元素1  元素2   元素3
        </td>
    </tr>
    <tr>
        <td>
            元素1  元素2   元素3
        </td>
        <td>
            元素1  元素2   元素3
        </td>
        <td>
            元素1  元素2   元素3
        </td>
    </tr>

   </table>
</body>
</html>

预览的页面:

3.html属性

1.链接和图像标签

  • <a>: 创建超链接,使用href属性指定链接目标。
  • <img>: 插入图像,使用src属性指定图像源,使用alt属性提供替代文本。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>html属性练习</title>
</head>
<body>
    <a href="https://blog.csdn.net/m0_72047169?spm=1011.2648.3001.5343"这是编程的幸博客的超链接></a>
    <br>
    <a href="https://www.csdn.net/?spm=1001.2014.3001.4476"这是CSDN的官网></a>
    <hr>
    <img src="logo.jpg" alt="">
    <br>
    <img src="log.jpg" alt="图片无法显示">
    <br>
    <img src="https://ts1.cn.mm.bing.net/th/id/R-C.12434b90457d0de13ddc788b4c56d2cb?rik=aJrmglWgZGmaHg&riu=http%3a%2f%2fi1.hdslb.com%2fbfs%2farchive%2f78444bc11cf3d70560d425bc77173a7f601f0b84.jpg&ehk=lCKo5eR5Y8rUIB9LnWnSLUH3NOvrE8TGyDDUEo%2btzQw%3d&risl=&pid=ImgRaw&r=0" alt=""width="450"height="300">
</body>
</html>

预览的页面:

4.html区块

 1.其他常用标签

  • <div>: 定义文档中的分区或块,用于布局。
  • <span>: 定义文档中的行内元素,用于样式。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>html区块练习</title>
</head>
<body>
    <div class="nav"> 
        <a href="a">链接1</a>
        <a href="a">链接2</a>
        <a href="a">链接3</a>
        <a href="a">链接4</a>
    </div>
    <div class="content">
        <h1>文章标题</h1>
        <p>文章内容</p>
        <p>文章内容</p>
        <p>文章内容</p>
        <p>文章内容</p>
        <p>文章内容</p>
    </div>
    <span>这是第1个span标签</span>
    <br>
    <span>这是第2个span标签</span>
    <br>
    <span>这是第3个span标签</span>
    <br>
    <span>这是第4个span标签</span>
    <hr>
    <span>链接点击这里<a href="a">链接</a></span>
</body>
</html>

预览的页面:

5.html表单

1. 表单标签

  • <form>: 定义表单,包含用户输入的区域。
  • <input>: 创建输入字段,type属性定义输入类型(如textpasswordsubmit等)。
  • <label>: 为输入元素定义标签。
  • <textarea>: 创建多行文本输入区域。
  • <button>: 创建按钮。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>html表单练习</title>
</head>
<body>
    <form action="">
        <label for="username">用户名:</label>
        <input type="text" id="username" placeholder="请输入用户名">
        <br><br>
        <label for="pwd">密码:</label>
        <input type="password" id="pwd" placeholder="请输入密码">
        <br><br>
        <label >性别</label>
        <input type="radio" name="gender">男
        <input type="radio" name="gender">女
        <input type="radio" name="gender">武装直升机
        <br><br>
        <label >爱好:</label>
        <input type="checkbox" name="hobby">唱歌
        <input type="checkbox" name="hobby">篮球
        <input type="checkbox" name="hobby">rap
        <input type="checkbox" name="hobby">篮球
        <br><br>
        <input type="submit">
    </form>

    <form action="#"></form>
</body>
</html>

预览的页面:

二、CSS

1. CSS(层叠样式表)

作用:
CSS 用于控制网页的外观和布局。它允许开发者设置颜色、字体、间距、布局等样式,从而美化网页。

特点:

  • 样式分离: CSS 与 HTML 分离,增强了维护性和可重用性。
  • 响应式设计: 通过媒体查询,可以为不同设备设置不同样式。
  • 层叠性: 多个样式可以叠加应用,优先级可以通过选择器的特异性控制。

2.css样式

1. 内部样式

定义:内部样式是将CSS规则直接放在HTML文档的<head>部分,通过<style>标签定义。

2. 内联样式

定义:内联样式是将CSS规则直接添加到HTML元素的style属性中。

3. 外部样式

定义:外部样式是将CSS规则保存在独立的.css文件中,然后在HTML文档中通过<link>标签引入。

优先级:内联 > 内部 >外部

外部样式

内部样式和内联样式

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<link rel="stylesheet" href="css/style.css">
<style>
    p{
        color: blue;
        font-size: 16px;
    }

    h2{
        color:chocolate;
        font-size:20px;
    }
</style>
<body>
    <p>这是一个内部样式,优先级次</p>
    <h1 style="color: red;">使用的是内联样式,优先级最高</h1>
    <h3>使用的是外部样式,优先级最低</h3>

</body>
</html>

预览的页面:

3.css选择器

  • 通用选择器(*):选择所有元素。
  • 元素选择器(tag):选择特定类型的元素。
  • 类选择器(.classname):选择具有特定类的元素。
  • ID选择器(#idname):选择具有特定ID的元素。
  • 属性选择器:根据元素的属性选择元素。
  • 伪类选择器:选择元素的特定状态。
  • 伪元素选择器:选择元素的一部分。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
    /* 元素选择器 */
    h1{
        color: red;
    }
    /* 类选择器 */
    .header{
        font-size: 20px;
    }

    /* id */
    #big{
        background-color: blue;
    }

    /* 通用选择器 */
    *{
        font-family: 'KaiTi';
        font-weight: bolder;
    }

    /* 子类选择器 */
    .father> .son{
        color: aqua;
    }

    /* 后代选择器 */
    .father p{
        color:blueviolet;
    }

    /* 相邻选择器 */
    h4 + p{
        background-color: red;
    }

    /* 伪类选择器 */
    #big1:hover{
        background-color: mediumblue;
    }

    /* 伪元素选择器 
    ::after
    ::before
    */

    /* 选择第一个子元素
    :first-child
    :nth-child()
    :active
    
    */
</style>
<body>
    <h1>这是一个元素选择器</h1>

    <h2 class="header">这是一个类选择器</h2>

    <h3 id="big">这一个id选择器</h3>

    <div class="father">
        <p class="son">
            这是一个子类选择器
        </p>
        <div>
            <p class="grandson">
                这一个后代选择器
            </p>
        </div>
    </div>

    <p>相邻,但位于上方</p>
    <h4>这是一个相邻选择器,选中的是紧跟它之后的第一个标签</h4>
    <p>相邻,紧跟在后面的</p>

    <h2 id="big1">这是一个伪类选择器</h2>
</body>
</html>

预览的页面:

这里伪类选择器的效果是,鼠标在上背景变紫色

4.css常用属性

  • 颜色与背景

    • color: 文字颜色。
    • background-color: 背景颜色。
    • background-image: 背景图像。
  • 文本

    • font-size: 字体大小。
    • font-family: 字体类型。
    • text-align: 文本对齐方式。
  • 边距与填充

    • margin: 外边距。
    • padding: 内边距。
  • 边框

    • border: 边框的宽度、样式和颜色。
    • border-radius: 圆角边框。
  • 尺寸与位置

    • width: 元素宽度。
    • height: 元素高度。
    • display: 元素的显示类型(如 blockinlineflex 等)。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>css常用属性</title>
</head>
<style>

    /* 块元素可以进行长宽的调整 */
    .block{ 
        background-color:blue;
    }

    /* 行内元素则不行 */
    .inline{
        background-color: aqua;
    }

    /* 行内块元素有行内和块两个元素的特点 */
    .inline-block{
        width: 200px;
        height: 200px;
    }

    /* 使用diplay进行相互的转换 
    .block{
        display: inline-block;
    }

    .inline{
        display: block;
    }

    .inline-block{
        display: inline;
    }
    */
    

</style>
<body>
    <h2 style="color: red 50px 'KaiTi';">这是一个复合元素</h2>
    <p style="line-height: 50px;">这是一个长文本这是一个长文本这是一个长文本这是一个长文本这是一个长文本这是一个长文本这是一个长文本这是一个长文本这是一个长文本这是一个长文本这是一个长文本这是一个长文本</p>

    <div class="block">这是一个块元素</div>
    <span class="inline">这是一个行内元素</span>
    <img class="inline-block" src="logo.jpg" alt="">
    <img class="inline-block" src="logo.jpg" alt="">
</body>
</html>

预览的页面:

5.css盒子模型

盒子模型是CSS布局的基本概念,它描述了元素的结构,包括:

  • 内容区域:元素的实际内容(文本、图像等)。
  • 内边距(padding):内容与边框之间的空间。
  • 边框(border):包围内边距和内容的线。
  • 外边距(margin):元素与其他元素之间的空间。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>css盒子模型</title>
</head>
<style>
    .demo{
        background-color: red;
        width: 100px;
        height: 100px;
        border: 10px dashed blue;
        padding: 20px;
        margin: 30px;
    }
    

    /* soild:实线 dashed:虚线 dotted:点线  double: 双线*/
    /* padding 内边距 margin 外边距 */
    .broder-demo{
        background-color: aqua;
        width: 100px;
        height: 150px;
        border-style: solid dashed dotted double;
        border-color: brown red blue blueviolet;
        border-width: 50px 10px 0 20px;
        padding: 50px;
        margin: 30px;
    }


</style>
<body>
    <div class="demo">这是一个盒子模型</div>
    <div class="broder-demo">这是一个盒子模型的边框示例</div>
</body>
</html>

预览的页面:

6.浮动

浮动(float)是CSS布局的一种方式,通常用于文本环绕和多列布局。使用浮动时,元素会向左或向右移动,其他元素会围绕它。使用浮动的常见方式:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>浮动</title>
</head>
<style>
    .father{
        background-color: blueviolet;
        /* height: 100px; */
        /* 高度没有了,出现坍塌 */
        border: 5px red solid;
        /* 使用overflow或者::after */
        overflow: hidden;
    }

    /* .father::after{
        content: "";
        display: table;
        clear: both;
        这一段也可以消除没有给父元素,设置高度时,解决坍塌作用
    } */

    .left-son{
        width: 100px;
        height: 100px;
        background-color: yellowgreen;
        float: left;
    }

    .right-son{
        width: 100px;
        height: 100px;
        background-color: brown;
        float: right;
    }
</style>
<body>
    <div class="father">
        <div class="left-son">
            <p>左浮动</p>
        </div>
        <div class="right-son">
            <p>右浮动</p>
        </div>
    </div>
    <p>这是一段文本内容</p>
</body>
</html>

预览的页面:

7.定位

定位用于控制元素在页面中的位置。常见的定位方式包括:

  • 静态定位(static):默认值,元素按正常流排列。
  • 相对定位(relative):相对于其原始位置进行定位。
  • 绝对定位(absolute):相对于最近的已定位父元素(非静态)进行定位。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<style>
    .box{
        height: 300px;
        background-color: yellow;
    }

    .box-normal{
        width: 100px;
        height: 100px;
        background-color: blue;
    }

    .box-relative{
        width: 100px;
        height: 100px;
        background-color: pink;
        position:relative;
        left:120px;
        top:50px;
    }


    .box1{
        height: 300px;
        background-color: yellow;
        margin-bottom: 100px;
    }

    .box-absolute{
        width: 100px;
        height: 100px;
        background-color: pink;
        position:absolute;
        left:120px;
    }

    .box-fixed{
        width: 100px;
        height: 100px;
        background-color: red;
        position: fixed;
        right: 0;
        top: 300px;
    }
</style>
<body>
    <h1>相对定位</h1>
    <div class="box">
        <div class="box-normal"></div>
        <div class="box-relative"></div>
        <div class="box-normal"></div>
    </div>

    <h1>绝对定位</h1> 
    <div class="box1">
        <div class="box-normal"></div>
        <div class="box-absolute"></div>
        <div class="box-normal"></div>
    </div>

    <h1>固定定位</h1>
    <div class="box-fixed"></div>
</body>
</html>

预览的页面:

绝对定位就是图中红色方块

三、JS(JavaScript)

1. JavaScript

先搞懂:这个与java无关,但重要!!!

JavaScript 的作用
其应用领域包括但不限于JavaScript 在前端开发中扮演着重要的角色

  • 客户端脚本:用于在用户浏览器中执行,实现动态效果和用户交互。
  • 网页开发:与HTML和 CSS 协同工作,使得网页具有更强的交互性和动态性。
  • 后端开发:使用Node.js,JavaScrip也可以在服务器端运行,实现服务器端应用的开发

特点:

  • 动态性: 可以在页面加载后动态更新内容。
  • 事件驱动: 可以响应用户操作(如点击、滚动等)。
  • 广泛应用: 可以与后端服务交互,实现复杂的应用逻辑。

2.JavaScript 导入

外部导入

内部导入

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>JS的导入方式</title>
    <script>
        console.log('Hello,head标签中内联样式');
    </script>
    <script src="./js/script.js"></script>
</head>
<body>
    <h1>JavaScript的导入方式</h1>
    <script>
        console.log('Hello,body标签中内联样式');
        alert('Hello,JS的导入方式');
    </script>
</body>
</html>

预览的页面:

3.JavaScript 语法

基本语法:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>JS基本语法</title>
</head>
<body>
    <script>
        // var不常用
        // let 整数,字符串  const 精度
        var x;
        let y = 3;
        const p = 3.14 
        let name ="猪猪侠";
        let empty_value = null;
        console.log(x,y,p);
        console.log(name);
        console.log(empty_value);
        
        console.log('if语句');
        //if条件
        let time = 8
        if (time < 12) {
            console.log('早上好!');
        }else if(time > 12 && time <14){
            console.log('中午好!');
        }else if(time > 14 && time < 18){
            console.log('下午好!');
        }else{
            console.log('晚上好!');
        }

        console.log('switch语句');
        let day = 1;
        switch (day) {
        case 1:
             console.log("Monday");
             break;
        case 2:
             console.log("Tuesday");
             break;
        default:
             console.log("Another day");
        }


        console.log('for循环');
        //for循环
        for (let i = 0; i <= 10; i++) {
            console.log(i);
        }
        

        console.log('while循环');
        //while循环
        let count = 0;
        while(count <= 10){
            console.log(count);
            count++;
        }


        console.log('do-while循环');
        //do-while循环
        let i = 0;
        do {
             console.log(i);
             i++;
        } while (i < 5);
        
        
        console.log('嵌套');
        //嵌套
        for (let i = 0; i <= 10; i++) {
            if(i==2){
                continue;
            }
            if (i==6) {
                break;
            }
            console.log(i);
        }
        
    </script>
</body>
</html>

预览的页面:

4.JavaScript 函数

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>JS函数</title>
</head>
<body>
    <script>
        function name() {
            console.log('孙悟空');
        }
        name();

        function name1() {
            return '返回->孙悟空!'
        }
        let a = name1();
        console.log(a);
        console.log(name1());

        function name_with_params(name) {
            console.log(name);
        }

        name_with_params('Alice');
        name_with_params('Emma');

        //作用域
        let globar_var = '全局变量';
        function local_var_function(){
            let local_var = '局部变量';
            console.log('打印全局变量:'+ globar_var);
            console.log('打印全局变量:'+ local_var);
        }

        local_var_function();
    </script>
</body>
</html>

预览的页面:

5.JavaScript 事件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>JS事件</title>
</head>
<body>
    <button onclick="click_event()">点击事件</button>
    <input type="text" onfocus="focus_event()" onblur="blur_event()">
    <script>
        function click_event() {
            alert('点击事件触发');
        }

        function focus_event() {
            console.log('获取焦点');
        }

        function blur_event() {
            console.log('失去焦点');
        }
    </script>
</body>
</html>

预览的页面:

6.JavaScript DOM

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>JS DOM</title>
</head>
<body>
    <div id="box1">ID选择器标签</div>
    <div class="box2">类选择器标签</div>
    <div>无选择器的div标签</div>
    <button>点击按钮</button>

    <script>
        var element_id = document.getElementById('box1');
        console.log(element_id);
        
        var element_class = document.getElementsByClassName('box2')[0];
        console.log(element_class);
        
        var element_tag = document.getElementsByTagName('div')[2];
        console.log(element_tag);


        element_id.innerHTML = '<a href="#">跳转链接</a>';
        //innerTest不识别链接
        element_class.innerText = '<a href="#">跳转链接</a>';


        element_tag.style.color = 'red';
        element_tag.style.fontsize = '30px';


        //DOM属性绑定事件
        var button_element = document.getElementsByTagName('button')[0];
        console.log(button_element);
        
        // button_element.onclick = function() {
        //     alert('DOM 属性绑定事件');
        // }

        button_element.addEventListener('click',function () {
            alert('点击就触发事件!');
        });
    </script>
</body>
</html>

预览的页面:

6.1 练习-表格的增删改查

DOM常用方法:

1. 选择元素

getElementById(id):根据元素的 ID 选择单个元素。

  const element = document.getElementById('myElement');

getElementsByClassName(className):根据类名选择一组元素(返回一个 HTMLCollection)。

  const elements = document.getElementsByClassName('myClass');

getElementsByTagName(tagName):根据标签名选择一组元素(返回一个 HTMLCollection)。

  const elements = document.getElementsByTagName('div');

querySelector(selector):根据 CSS 选择器选择单个元素。

const element = document.querySelector('.myClass');

querySelectorAll(selector):根据 CSS 选择器选择一组元素(返回一个 NodeList)。

const elements = document.querySelectorAll('div.myClass');

2. 创建和插入元素

createElement(tagName):创建一个新的元素。

const newDiv = document.createElement('div');

appendChild(node):将节点添加到指定父节点的末尾。

  const parent = document.getElementById('parent');
  parent.appendChild(newDiv);

insertBefore(newNode, referenceNode):在指定的子节点前插入一个新节点。

  const referenceNode = document.getElementById('reference');
  parent.insertBefore(newDiv, referenceNode);

3. 修改元素

textContent:设置或获取元素的文本内容。

  element.textContent = 'Hello, World!';

innerHTML:设置或获取元素的 HTML 内容。

  element.innerHTML = '随便写写什么';

setAttribute(name, value):设置指定属性的值。

  element.setAttribute('class', 'newClass');

getAttribute(name):获取指定属性的值。

  const className = element.getAttribute('class');

4. 删除元素

removeChild(node):从 DOM 中删除指定的子节点。

  parent.removeChild(element);

remove():从 DOM 中删除当前元素。

  element.remove();

5. 事件处理

addEventListener(event, function):为指定元素添加事件监听器。

  element.addEventListener('click', function() {
      alert('Element clicked!');
  });

removeEventListener(event, function):移除指定元素的事件监听器。

  element.removeEventListener('click', myFunction);

6. 样式操作

style:直接操作元素的 CSS 样式。

  element.style.color = 'red';

classList:用于添加、删除和切换 CSS 类。

  element.classList.add('active');
  element.classList.remove('active');
  element.classList.toggle('active');

外部部署的js

//新增数据类型
function addRow() {
    var table = document.getElementById('table');
    //获取插入的位置
    var length = table.rows.length;
    
    // //插入行节点
    var newRow = table.insertRow(length);
    console.log(newRow);

    //插入行节点对象
    var nameCol = newRow.insertCell(0);
    var phoneCol = newRow.insertCell(1);
    var addressCol = newRow.insertCell(2);
    var actionCol = newRow.insertCell(3);

    //修改节点文本内容
    nameCol.innerHTML = '未命名';
    phoneCol.innerHTML = '无联系方式';
    addressCol.innerHTML = '无住址';
    actionCol.innerHTML = '<button  onclick="editRow(this)">编辑</button> <button onclick="deleteRow(this)">删除</button>';
}

//删除数据函数
function deleteRow(button) {
    var row = button.parentNode.parentNode;
    console.log(row);
    row.parentNode.removeChild(row); 
}

//编辑数据函数
function editRow(button) {
    var row = button.parentNode.parentNode;
    var name = row.cells[0];
    var phone = row.cells[1];
    var address = row.cells[2];

    var inputName = prompt("请输入名字:");
    var inputPhone = prompt("请输入联系方式:");
    var inputAddress = prompt("请输入住址:");
   
    name.innerHTML = inputName;
    phone.innerHTML = inputPhone;
    address.innerHTML = inputAddress;
}

.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>CRUD</title>
</head>
<style>
    table{
        width: 100%;
        /* 边框合并 */
        border-collapse: collapse;
        margin-top: 20px;
    }

    th,td{
        border:1px solid #ddd;
        text-align: center;
        padding: 10px;
    }
    th{
        background-color: #ddd;
    }

    button{
        margin-left: 5px;
    }
</style>
<body>
    <h1 style="text-align: center;">表格的CRUD</h1>
    <button onclick="addRow()">添加数据</button>
    <table id="table">
        <tr>
            <th>姓名</th>
            <th>联系方式</th>
            <th>住址</th>
            <th>操作</th>
        </tr>

        <tr>
            <td>猪八戒</td>
            <td>13989890000</td>
            <td>高老庄</td>
            <td><button onclick="editRow(this)">编辑</button><button onclick="deleteRow(this)">删除</button></td>
                
        </tr>
    </table>
    <script src="./js/tableTest.js"></script>
</body>
</html>

预览的页面:

 新增和编辑

 删除:

7.移动端适配及 rem

  • width=device-width`:将视口的宽度议设置为设备的宽度。这确保网页内容不会被丝,而是按照设备的实际宽度进行布局,
  • initial-scale=1.0:设置初始的缩放级别为 1.0。这也有助于确保网页在加载时,以原始大小显示,而不是被缩小或放大;
  • minimum-scale=1.0:最小缩放比例为1
  • maximum-scale=1.0`:最大缩放比例为1
  • user-scalable=no不允许用户缩放
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>rem和适配</title>
</head>
<style>
    /* html{
        font-size: 20px;
    } */
    .box-px{
        width: 300px;
        height: 100px;
        background-color: aqua;
        margin-bottom: 100px;
    }

    .box-rem{
        width: 5rem;
        height: 3rem;
        background-color: blueviolet;
    }
</style>
<body>
    <div class="box-px">固定布局</div>
    <div class="box-rem">自适应布局</div>

    <script>
        function testFontSize() {
            document.documentElement.style.fontSize = screen.width / 10 + 'px';
        }

        testFontSize();

        window.onresize = testFontSize;
    </script>
</body>
</html>

预览的页面:

8.Flex 弹性盒子与容器属性

flex-direction

属性值描述主轴方向
row项目从左往右排列水平方向
row-reverse项目从右往左排列水平方向
column项目从上往下排列垂直方向
column-reverse项目从下往上排列垂直方向

flex-wrap

属性值描述换行方式
nowrap默认值,不换行,所有项目排列在一条轴线上不换行
wrap当一条轴线排不下时,项目换行从上到下换行(主轴为横向)<br>从左到右换列(主轴为纵向)
wrap-reverse当一条轴线排不下时,项目反向换行从下到上换行(主轴为横向)<br>从右到左换列(主轴为纵向)

justify-content

属性值描述
flex-start默认值,与主轴的起点对齐
flex-end与主轴的终点对齐
center与主轴的中点对齐
space-between两端对齐,项目之间的间隔相等
space-around每个项目两侧的间隔相等,项目之间的间隔比项目与边框的间隔大一倍

align-items

属性值描述
flex-start交叉轴的起点对齐
flex-end交叉轴的终点对齐
center交叉轴的中点对齐
baseline项目的第一行文字的基线对齐
stretch如果项目未设置高度或设为 auto,项目将占满整个容器的高度

 align-content

属性值描述
flex-start与交叉轴的起点对齐
flex-end与交叉轴的终点对齐
center与交叉轴的中点对齐
space-between与交叉轴两端对齐,轴线之间的间隔平均分布
space-around每根轴线两侧的间隔相等,轴线之间的间隔比轴线与边框的间隔大一倍
stretch主轴线占满整个交叉轴
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Flex和容器属性</title>
</head>
<style>
    html{
        font-size: 10px;
    }

    .container{
        display: flex;
        height: 40rem;
        background-color: aqua;
        /* 属性测试 */
        /* flex-direction
           row            左->右
           row-reverse    右->左
           column         上->下
           column-reverse 下->上
        */
        /* flex-direction:column; */

        /* flex-wrap
           nowrap     不换行or列
           wrap       横向 上->下换行 纵向 下->上
           wrap-reverse   相反情况
        */
        /* flex-wrap: wrap-reverse; */

        /* justify-content
           flex-start
           flex-end
           center
           space-between
           space-around
         */
         /* justify-content: space-around; */

        /* align-items
           flex-start
           flex-end
           center
           baseline
           stretch
         */
         /* align-items:baseline; */

        /* align-content
           flex-start
           flex-end
           center
           space-between
           space-around
           stretch
        */
    }

    .item{
        width: 100px;
        font-size: 6rem;
    }
</style>
<body>
    <div class="container">
        <div class="item" style="background-color: blue;">1</div>
        <div class="item" style="background-color: brown;">2</div>
        <div class="item" style="background-color: green;">3</div>
        <div class="item" style="background-color: blueviolet;">4</div>
        <div class="item" style="background-color: yellow;">5</div>
        <div class="item" style="background-color: red;">6</div>
    </div>
</body>
</html>

预览的页面:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2234696.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Zabbix proxy 主动模式的实现

1. 准备三台机器 zabbix-server10.0.0.200zabbix-agent10.0.0.203zabbix-proxy10.0.0.204 2. 创建独立的数据库&#xff08;最好部署在单独的机器上&#xff0c;或者部署在porxy机器上&#xff09; # 按照官网下载 proxy 的步骤中创建库和用户即可 # mysql -uroot -p passwo…

【linux】的爱恨情仇

Linux发展史&#xff1a;一段关于黑客、企鹅和科技巨头们的传奇冒险 个人主页&#xff1a;chian-ocean 文章专栏 各位朋友们&#xff0c;欢迎来到Linux的世界&#xff01;今天&#xff0c;我将带你们进入一段不拘一格的故事&#xff0c;充满了怪咖、极客、反派巨头&#xff…

微服务系列二:跨微服务请求优化,注册中心+OpenFeign

目录 前言 一、纯 RestTemplate 方案存在的缺陷 二、注册中心模式介绍 三、注册中心技术&#xff1a;Nacos 3.1 Docker部署Nacos 3.2 服务注册 3.3 服务发现 四、代码优化&#xff1a;OpenFeign工具 4.1 OpenFeign快速入门 4.2 连接池的必要性 4.3 抽取服务、最佳实…

SRS:构建实时免费视频服务器的全方位指南

SRS&#xff08;Simple Realtime Server&#xff09;是一个开源的、基于MIT协议的实时视频服务器&#xff0c;以其简单、高效而著称。它支持多种流媒体协议&#xff0c;包括RTMP、WebRTC、HLS、HTTP-FLV、SRT、MPEG-DASH和GB28181等&#xff0c;使其成为直播和WebRTC领域的理想…

copilot教我学408---OS之文件管理

四、文件管理 (一)文件 1.文件的基本概念 2.文件元数据和索引节点(inode) 3.文件的操作 建立,删除,打开,关闭,读,写 4.文件的保护 5.文件的逻辑结构 6.文件的物理结构 (二)目录 1.目录的基本概念 2.树形目录 3.目录的操作 4.硬链接和软链接 (三)文件系统 1.文件系统的全局结构(…

论文阅读笔记:Activating More Pixels in Image Super-Resolution Transformer

论文阅读笔记&#xff1a;Activating More Pixels in Image Super-Resolution Transformer 1 背景1.1 问题1.2 提出的方法 2 创新点3 方法4 模块4.1 混合注意力模块&#xff08;HAB&#xff09;4.2 重叠交叉注意力模块&#xff08;OCAB&#xff09;4.3 同任务预训练 5 效果5.1 …

导师双选系统开发:Spring Boot技术详解

第一章 绪论 1.1 选题背景 如今的信息时代&#xff0c;对信息的共享性&#xff0c;信息的流通性有着较高要求&#xff0c;尽管身边每时每刻都在产生大量信息&#xff0c;这些信息也都会在短时间内得到处理&#xff0c;并迅速传播。因为很多时候&#xff0c;管理层决策需要大量信…

关于wordpress instagram feed 插件 (现更名为Smash Balloon Social Photo Feed)

插件地址&#xff1a; Smash Balloon Social Photo Feed – Easy Social Feeds Plugin – WordPress 插件 | WordPress.org China 简体中文 安装后&#xff0c;配置教程&#xff1a; Setting up the Instagram Feed Pro WordPress Plugin - Smash Balloon 从这里面开始看就…

Redis学习:BitMap/HyperLogLog/GEO案例 、布隆过滤器BloomFilter、缓存预热+缓存雪崩+缓存击穿+缓存穿透

Redis学习 文章目录 Redis学习1、BitMap/HyperLogLog/GEO案例2. 布隆过滤器BloomFilter3. 缓存预热缓存雪崩缓存击穿缓存穿透 1、BitMap/HyperLogLog/GEO案例 真实需求面试题 亿级数据的收集清洗统计展现对集合中数据进行统计&#xff0c;基数统计&#xff0c;二值统计&#xf…

基于Python的智能旅游推荐系统设计与实现

一、摘要 本毕业设计的内容是设计并且实现一个基于Python技术的智能旅游推荐系统。它是在Windows下&#xff0c;以MYSQL为数据库开发平台&#xff0c;使用Python技术进行设计。智能旅游推荐系统的功能已基本实现&#xff0c;主要实现首页&#xff0c;个人中心&#xff0c;用户…

从零开始的c++之旅——多态

1. 多态的概念 通俗来说就是多种形态。 多态分为编译时多态&#xff08;静态多态&#xff09;和运行时多态&#xff08;动态多态&#xff09;。 编译时多态主要就是我们之前提过的函数重载和函数模板&#xff0c;同名提高传不同的参数就可以调 用不同的函数&#xff0c…

第二十六章 Vue之在当前组件范围内获取dom元素和组件实例

目录 一、概述 二、获取dom 2.1. 具体步骤 2.2. 完整代码 2.2.1. main.js 2.2.2. App.vue 2.3. BaseChart.vue 三、获取组件实例 3.1. 具体步骤 3.2. 完整代码 3.2.1. main.js 3.2.2. App.vue 3.2.3. BaseForm.vue 3.3. 运行效果 一、概述 我们过去在想要获取一…

plt中subplot综合实战

目录 背景介绍实战 背景介绍 下面是一份贸易数据&#xff08;Prod_Trade.xlsx&#xff09;&#xff0c;需要多角度针对2012年数据进行报表分析&#xff0c;需使用subplot分格展示。Prod_Trade的数据结构包括 Date,Order_Class,Sales Transport,Trans_Cost, Region ,Category, …

DevOps开发运维简述

DevOps平台是一套集成的解决方案&#xff0c;旨在协调软件开发&#xff08;Development&#xff09;和信息技术运维&#xff08;Operations&#xff09;。它促进跨功能团队合作&#xff0c;实现自动化流程&#xff0c;确保持续集成与持续交付&#xff08;CI/CD&#xff09;。 一…

基于java+SpringBoot+Vue的微服务在线教育系统设计与实现

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; Springboot mybatis Maven mysql5.7或8.0等等组成&#x…

粒子群优化双向深度学习!PSO-BiTCN-BiGRU-Attention多输入单输出回归预测

粒子群优化双向深度学习&#xff01;PSO-BiTCN-BiGRU-Attention多输入单输出回归预测 目录 粒子群优化双向深度学习&#xff01;PSO-BiTCN-BiGRU-Attention多输入单输出回归预测效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.Matlab实现PSO-BiTCN-BiGRU-Attention粒子…

终端文件管理神器 !!!

项目简介 nnn是一款专为命令行爱好者打造的高效终端文件管理器。它以其超小的体积、几乎零配置的要求以及卓越的速度表现而著称。nnn不仅适用于Linux、macOS、BSD等操作系统&#xff0c;还能够在诸如树莓派、Android上的Termux、WSL、Cygwin等多个平台运行。它遵循POSIX标准&am…

Uniapp 实现app自动检测更新/自动更新功能

实现步骤 配置 manifest.json 在 manifest.json 中设置应用的基本信息&#xff0c;包括 versionName 和 versionCode。 一般默认0.0.1&#xff0c;1. 服务器端接口开发 提供一个 API 接口&#xff0c;返回应用的最新版本信息&#xff0c;版本号、下载链接。客户端检测更新 使…

基础算法——排序算法(冒泡排序,选择排序,堆排序,插入排序,希尔排序,归并排序,快速排序,计数排序,桶排序,基数排序,Java排序)

1.概述 比较排序算法 算法最好最坏平均空间稳定思想注意事项冒泡O(n)O( n 2 n^2 n2)O( n 2 n^2 n2)O(1)Y比较最好情况需要额外判断选择O( n 2 n^2 n2)O( n 2 n^2 n2)O( n 2 n^2 n2)O(1)N比较交换次数一般少于冒泡堆O( n l o g n nlogn nlogn)O( n l o g n nlogn nlogn)O( n l…

多元数据库时代,云和恩墨携手鲲鹏引领数据库一体机新变革

近年来&#xff0c;随着企业数据存储结构日益多元化&#xff0c;传统架构数据库面临发展瓶颈&#xff0c;越来越多企业倾向于采用不同类型的数据库满足多样化的数据需求。这一趋势下&#xff0c;国内数据库市场呈现百花齐放的态势&#xff0c;产业加速迈入多元数据库时代。 作为…