🔥博客主页: A_SHOWY
🎥系列专栏:力扣刷题总结录 数据结构 云计算 数字图像处理 力扣每日一题_
学习前端全套所有技术性价比低下且容易忘记,先入门学会所有基础的语法(css+js+heml),常用示例,再根据项目上手练习,哪里不会查哪里是最好的学习方式
下载VSCode,然后安装三个插件,中文插件,HTML CSS Support(写CSS快捷神器),Live Server(实时预览页面的变化),Auto Rename Tag(修改HTMl标签时候,同步修与之匹配的另一个标签)
——为网页提供结构
他负责告诉浏览器某个部分是段落,图片视频还是列表,他是通过一系列的标签,双标签成对出现,开始标签和结束标签,内容在其之中。单标签没有结束标签,用于没有内容的元素。
可以观察页面
相比于段落标签,标题标签明显有一个加粗
border就是table标签的一个属性,里面的值边框的粗细
常用于链接位置,href属性定义链接的目标,target表明打开方式:_self是一个默认值,在当前窗口打开,_blank是在新窗口打开。_parent父窗口打开,_top在顶层窗口打开
src属性是可以是这个目录下直接写图像的名称,或者是网上的链接
alt属性是如果这个图像无法加载显示的字
块级标签,通常用于创建一个可以包含其他HTML元素的容器块,没有语义,用于组织内容,创建页面的布局结构,页眉,导航栏什么的
行内元素,作用是相当于没有特殊元素的a标签和img标签,把一些文本包装起来。便于对他们使用一些样式CSS,或者JS行为
他有很多属性,placeholder是给一个提示,value是直接给一个值
加一个span标签就能实现这样,但是input有自己对应的一个属性label
这个text属性是输入的形式,test就是文本 ,radio的话就是选择框
如果要实现单选,需要加一个name属性,而且这些name属性必须相一致,比如性别都是gender
一般与input中的id所对应的,id对于每个标签每个元素来说都是唯一的,在单选框用就不合适,可以在用户名中使用
直接把类别改成password
checkbox属性
需要后端提供给我们的API指定提交到哪里
一共三种导入方式,注意优先级
CSS样式放在html文档的head标签中
把CSS样式直接放在标签中
单独放在一个css文件中,在head里面使用link链接过来,允许多个页面重复使用相同样式。
以下是三种样式的一个组合
上文已经演示过了
.+类名
选择直接位于父元素内部的子元素,也就是一个大标签嵌套一个小标签
注意看这里要区别一下子代和后代的区别,第一个儿子p变成了黄绿色,而包含在里面的孙子没有变
注意一个顺序:id > 类 > 标签名 ,所以上面那个标签还是保持黄绿色,见下图
只渲染这个选定的标签之后的选择器
比如说鼠标放到一个标签上,有一些变化
鼠标悬停特效
以font为例子,补:行高
边框会用了其他同理
本质就是摆盒子,多种布局方式掺杂在一起
行内块不如这个浮动方便,而且这个浮动是在父元素中浮动的
现在是还没有添加浮动
现在设置左浮动和右浮动,发现都和行内块一样,占满一行再占用下一行
可以看到这时候设置了height,这个文本出现在后边 ,如果注释掉就出现了坍塌
浮动灵活不容易控制,定位可以精准定位
可以看出不脱离文档流
可以看出脱离文档流,紫色的那个块直接上去了 ,根据已经定位的父级元素进行定位的,这个是和固定定位有所区别的。
相对于浏览器窗口进行定位的,不管你怎么滑动滚轮,他这个位置是始终保持不变的
三种导入方式,(1)head的内联,(2)head的外联,(3)body的内联。他们有一定顺序
除了在控制台打印,可以弹窗打印,用alert
undefined是已被声明但是没有被赋值,可能将来被赋值,null被明确赋值为空或者不存在
和别的语言差不多 if else 和else if和c++差不多
也和c++很像
for和while都能实现
和c++也是一模一样
在函数内都没问题,但在外部打印局部变量就会报错
可以理解为获取这些标签节点,来对标签本身进行操作
按钮为例子,方式1:
方式2
如果带上括号,直接触发,且按钮失效
先写CSS和HTML部分
Document 表格的增删改查
姓名 联系方式 操作 cpy 1566545623
再写JS部分
新增数据部分:
完整部分
JS部分代码
//新增数据 function addRow(){ var table = document.getElementById('table'); // console.log(table); //获取插入的位置 var length = table.rows.length; // console.log(length); //插入行节点 var newRow = table.insertRow(length); console.log(newRow); //插入列节点 var nameCol = newRow.insertCell(0); var phoneCol = newRow.insertCell(1); var actionCol = newRow.insertCell(2); //修改节点文本的内容 nameCol.innerHTML = '未命名'; phoneCol.innerHTML = '无联系方式'; actionCol.innerHTML='' } //删除数据 function deleteRow(button){ // console.log(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 inputName = prompt("请输入姓名") var inputPhone = prompt("请输入手机号") name.innerHTML = inputName; phone.innerHTML = inputPhone; }
HTML+CSS部分
Document 表格的增删改查
姓名 联系方式 操作 cpy 1566545623
需要响应式布局适应不同大小和分辨率的移动设备屏幕
使用rem能保证一直占着屏幕宽度的一半