7天速成前端 ------学习日志 (继苍穹外卖之后)

前端速成计划总结:   全26h课程,包含html,css,js,vue3,预计7天内学完。

起始日期:9.16                 预计截止:9.22                每日更新,学完为止。

学前计划

课程来源

B站---Java程序员用学前端么?java开发所需的前端技术全教程

课程安排

学习时长总计

html,css             P1-P4                  3节                            3h

JavaScript            P5-P58                 50节*10min              8h

Vue 3                       P104 - P163         60节*15min              15h

合计总时长:            26h

学习目标

计划学习时长

基础:  有后端学习的基础。之前也了解过一点点前端的东西,但了解的很浅。

计划:每天按4h视频内容来算,最多7天学完。


Day--1        9.16

HTML

介绍

超文本

就是超链接,可以把不同的网页联系起来。

标记

不同的标记,赋予标记里的内容不同的含义。也叫做标签。

标准的html代码

样例

<html>      <head>     <body>

快捷键

文档声明

三个感叹号:   !!!

htnl的框架

一个感叹号:  !

标签

只输入标签的名字即可:  img    p



常见元素

 Html由一系列的元素组成。感觉和标签差不多一个意思。

标签特性

1.元素之间可以嵌套。但标签不能交叉。

2.空元素,不包含内容的元素称为空元素。

通用属性

id  :  用于区别相同标签

title : 

title 属性在 HTML 中主要用于提供额外的信息或描述,当鼠标悬停在某个元素上时,浏览器会显示该元素的 title 属性值作为工具提示(tooltip)。

示例效果

当你将鼠标悬停在上面的 <img> 标签、超链接或按钮上时,浏览器会在鼠标指针下方显示一个包含 title 属性值的小窗口。

实测有效,但没办法截图,因为需要鼠标悬停才会显示,截图时候,鼠标就消失了。

基础标签
<p>

段落标签。表示一个段落。

<br>

换行标签,会换行,页面内不可见。

<hr>

分割线标签,生成一个分割线

<h1>  <h2> .....  <h6>

1到6号标题,字体大小从大一次减小。

列表类标签

<li>

<ol>

<ul>

<a>  超链接
Anchor 标签

三种链接跳转方式

#的含义

表示,是在页面内跳转

多媒体标签

表单标签
介绍

基本用法

表单项


第一次前后端代码联调测试

表单提交测试

感慨

现在看起来,很简单啊哈哈,当时不了解的时候,可算是一头雾水。

有一些顿悟的意思了,原来前端提交的数据名称,可以在标签的属性里面指定,然后后端按属性名接收。

但目前他这个代码,返回数据以后,浏览器页面就直接刷新了,肯定后面还回学其他技术,来处理返回的数据,进行展示等等。



日期格式不一致  报错

错误原因: 前后端 日期的格式不一致


CSS

介绍

主要负责控制网页展现的样式。

全天总结

今天的的话,进展不多,但也算是起了一个头,还不错。本来今天休息的,但是对出去玩没什么兴趣,于是还是学了一会儿。


Day--2        9.17

全天总结

        今天呢,图书馆闭馆,所以一天都在宿舍了。前端没有进展,但是了解了一下怎么做动态壁纸,居然也是要用到前端语言实现一些动画效果的,也算蛮有意思。

        再看一本书,很喜欢,米兰昆德拉的《不能承受的生命之轻》。

        但是,重便是真的残酷,而轻便真的美丽?        

        总之,是很有哲学意味的一本书,引人深思,收获很多。

        不过后面呢,大概是要加快脚步了,只剩五天了。还好这也算是在考虑的范围内吧,五天应该也差不多,加油。


Day--3        9.18

前后端交互测试

代码

后端代码有误,可能是苍穹的Rest风格代码写习惯了,修改如下

无法请求到服务器

原因

刚刚调试了半天,请求没发出去,结果是因为,前端的URL 地址少写了一个冒号

解决

localhost后加上冒号

首测成功

换一种后端请求接收写法

发现也可以提交成功

原因分析

根据浏览器控制台网络请求,发现请求方式为GET,说明表单默认提交方式为get

  1. 后端代码的注解组合

    • @Controller 注解表示这是一个控制器类。
    • @RequestMapping("/test") 注解表示该控制器的所有请求都将映射到 /test 路径。
    • @GetMapping 注解表示这是一个 GET 请求处理器。
    • @ResponseBody 注解表示返回的内容将直接作为响应体返回给前端。

刚刚发布了一篇博客,专门讲这个的,算是清楚为什么了。

getMapping就是只处理改路径下的get请求,requestMapping就是所有类型请求都处理。

@ResposeBody

  @ResponseBody 是 Spring MVC 中的一个常用注解,它并不是新用法,而是自 Spring 3.0 版本以来就已经引入的功能。这个注解用于标记控制器方法的返回值,使得该方法的返回值可以直接作为 HTTP 响应体的一部分返回给客户端。

        不小心看出了@RequestBody ,疑惑了半天


进阶测试

简单实体参数

多个参数提交

报错

MethodArgumentNotValidException

根据日志信息,问题出现在以下方面:

  1. 类型不匹配

    • 请求中的日期字符串 2024-09-10 无法转换为 java.time.LocalTime 类型。这是因为 LocalTime 表示一天中的某个时刻(例如 13:45),而不表示日期。
  2. 期望的格式

    • 你的代码可能期望日期字符串为 LocalTime 的格式(例如 HH:mm),但实际上传递的是日期格式(例如 YYYY-MM-DD)。

解决方案

你需要更改日期字段的格式,使其符合 LocalTime 的要求。或者,你可以将日期字段改为 LocalDateLocalDateTime

测试结果

只能收到其中的一部分数据

推测原因,get方式请求不能携带date,多选框等组件传递的信息

修改请求提交方式

还是不行,测试结果不变

检查请求体信息,正常

原因:tostring方法不会打印所有参数,需要手动get出来,上面的几个猜测是错误的


文件上传注意事项

method   enctype

表单的熟悉值不能是默认的了,需要设置一下



理解

method   方法

enctype   编码方式

示例

测试成功


HTTP请求

表单请求方式

请求行

请求头

请求体

请求体用于携带数据

数据编码格式

application/x-www-form-urlencoded 

格式:

名字=值,多组数据间以&风格

示例:

multipart/form-data

application/json

@RequestBody  表示到请求体里找数据,并且把数据按照json的数据格式转化为Java对象

数据格式小结

反引号

``  JavaScript中只有反引号才支持换行

session原理

CSS

简介

头文件引入css

元素选择器

属性和值

大概就是选择器里里面设置样式的东西

布局

布局示例

div标签

容器标签,容纳其他标签

template标签

又叫模板标签

一般开始时不会在也页面中显示

要配合JavaScript事件,来动态的把它加入到其他div容器之内

JavaScripe


介绍

第一次JavaScript语句测试

变量与数据类型

声明变量的方式

let与var的区别

能用let就尽量不要用var,用var容易出作用域的问题。

数据类型

Nullish

String

number,bigint

默认为number,常用转化方法为parseInt()

要表示整数,在数据后面加n即可

bollean

对象类型

Function

Array

Object

全天总结

         今天状态还不错,但是还是没能赶上今天的计划内容。其实本来可以的,但我用一部分时间去实际写代码,解决报错什么的,还写一些分析博客。

        不过虽然慢了不少,但我想收获还是有的。继续加油吧。今天还起来晚了,中午才开始学习,明天应该进度会快一些的。


Day--4        9.19

JS数据类型

对象类型

Function

注意:函数和java中的方法是有区别的。因为js是动态语言。

匿名函数

箭头函数

函数是对象

函数作用域

类似于java,如果作用域在所有方法之外,就是全局作用域

闭包重点:作用域是在函数定义的时候就确定了。

Java中也有类似的特性

lamda表达式和它的参数捕获

Array

语法

常用API

高阶函数,回调函数

Object

语法

get,set

没有私有变量的概念

属性前加下划线只是一种普遍约定而已。

控制台直接输入._name也是可以访问到的,只不过不走get方法

而如果时.name就会走get方法访问该属性

特色:属性增删

添加get,set方法

this

let 与 var 区别

主要就是作用域的区别。用let和Java中的作用域用法更像。

继承

继承示例

  

原型继承

函数的prototype相当于是,你可以自己在这个属性上加一些模板属性和方法。

一点理解:

        1.函数的prototype相当于是,你可以自己在这个属性上加一些模板属性和方法。然后这个子对象就会根据你在prototype里设置的模板来创建

        2.原型继承,就是直接以对象实例为依据去继承。继承的方式就是先定义好父对象,然后用Object.creat()方法,传递父对象进去,然后创建子对象。而子对象特有的方法和属性,是在后续在加上的。

        3.java的继承发生在类上,js的继承发生在对象上

Json与js对象的关系

格式上的相似

区别

json字符串与js对象的转换

动态类型语言JS

运算符,表达式

基础运算符

严格相等

逻辑或运算

值1   ||   值2

总结:如果值1是truthy ,返回值1,值1是flasy,返回值2.

双问号,问好点

双问号

值1  ??值2           如果值为nullish  ,返回右边  ,反之,返回自身

问好点

?.      就是在访问属性的时候做一个判断,如果属性为nullish,则短路返回undifined

展开运算符

注意:展开表达式的复制,属于浅拷贝

合并对象时,后定义的属性会覆盖先定义的同名属性

解构赋值

控制语句

for in

for of

try catch

nvm,Nodejs下载

需要去git官网发布页

配置下载的国内镜像地址,查看可用的版本

好烦,下载的太慢了,也可能是镜像地址没设置成功

总之半天没能解决这个问题。

也许是网速太慢了,等我回宿舍了再试试。

全天总结

        今天总的来说,情况还不错,该学的时候都在学习,继续保持吧。要不是最后下载出来点问题,可以一直把api部分学完 。但目前情况看来,api之内留到明天学了。


Day--5        9.20

下载Nodjs  npm

忙了早上好久,终于快要下载好nodejs和npm了

镜像网址

淘宝的镜像地址目前我访问不了,京东和华为的镜像地址都可以用

更新npm

因为我不能用nvm自动下载nodejs和npm,所以我是自己直接去镜像资源网址下载的,然后安装到nvm的目录下了。

但是npm版本有点问题,就更新了一下版本。

配置环境变量

        我丢,服啦,本来都是那个安装程序自动完成的,结果出问题,都得我自己来弄。

        唉,不过也确实熟悉了这一套操作也挺好的,今天昨天,输了一堆命令,改配置文件,找镜像资源网址。也算是锻炼了能力,同时加深了理解。

初始化工程

更改配置

导包相关的一个配置

node命令在终端用不了,cmd就能用

api部分

课前配置

导入前端代码

后端服务启动

数据库连接,创建表


查询api

document.querySelector('')

查询,返回所有匹配到的元素中的第一个。

document.querySelectorAll()

document.getElementById()

注意

quert方法调用时要符合规范,class加.    id加#


修改api

innerHTML()

可以再内容中加html标签,标签会被解析

textContent()

不会解析html标签,只会以文本的形式添加。

清空某一个标签

用以上两个方法,设置值为空字符串  '' 即可


利用模版

复制一个对象

document.importNode(row, true)

第一个参数 :复制的对象      第二个参数:是否连着子标签一起复制 

获取一个标签里的所有内容

tp.content

建立父子关系

tbody.appendChild(newRow)


同步接收结果  异步接受结果

前端接收后端数据的API


跨域

同源策略

        当浏览器访问前端页面时,前端页面会返回一个前端页面的副本给浏览器,然后浏览器继续访问,如果访问的资源也是前端服务器,那请求可以正常返回。但是如果访问的是其他的服务器,为了确保数据安全性,浏览器不会接受这个响应。

解决策略

给后端返回的响应头加一个属性,表明这个请求可以被哪些地址访问

刚刚测试同步异步请求遇到一个报错

查了一下,感觉可能是数据库没连上,重启了一下mysql服务但还是报错

突然感觉是配置文件没改,看了一下还真是,要改成自己数据库的名字

我的配置文件修改后,还是报错

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/架构_students spring.datasource.username=root spring.datasource.password=123456

注意事项: 数据库的名称不能带中文,否则还会报错

再次修改后,成功运行服务

请求发送成功了,但数据为空

这是因为处理后端数据的方式不对,修改如下

同步异步请求测试成功

代理解决同源跨域问题

使用代理,就不会发生跨域

配置代理,下载插件

修改启动类代码如下,可以正常启动服务


导入导出

导出语法

导入语法


Day--6        9.21

嘶,被夸了,有点开心哈哈。谢谢哦~

第一次建构Vue项目

项目构建

运行Vue服务器的命令

刚刚找了半天呜呜呜

全天总结

今天学习上还行吧,但是Vue这的安装下载又用了好多时间,有点烦呢,不做了,明天再学吧,最后一天了,时间可能不太够。但也就是了解一下前端,需求也不高,后面最后一天结束后就直接继续后端开发了。

哎呀,服了,原来刷新一下页面就可以搞定插件的问题

害的我搞了好久,啊啊啊

好吧,还是不能轻易放弃前端的,要好好学,不能轻易放弃,我将来可得做全栈的。

回宿舍了继续学,心情好多了哈哈哈,加油加油。


Day--7        9.22

星期天,休息了一天。


Day--8        9.23

        今天突然对社科政治哲学感兴趣,了解学习了一天相关的知识。虽然没有推进计划,但也解决了我不少困惑,感觉是成长不可或缺的一步。


Day--9        9.24

运行vue项目的命令

到命令提示符,输入命令:  nmp run dev

修改启动端口号

代理服务器配置成功,解决跨域问题

vue工程目录结构

Ts入门

安装编译器

npm install -g typescript

数据类型

变量类型声明

注意:很多可以进行类型推断的时候,可以省略类型声明

定义复杂类型

可选属性   ?:    

注意: 可选属性,要注意调用时的undifind处理。

鸭子类型,ts中的类型检查特点

方法定义

字面量类型

Nullish类型   null undifind如何使用

泛型

定义泛型

使用泛型

泛型函数定义

意义

1.给了用户更好的提示

2.越来越多的框架使用了TS,可以更好的阅读源码

3.可以使用泛型等,给了编译时的类型检查等,增加代码健壮性。、

类,class语法

入门案例

响应式变量

两种方式,变为响应式数据 ref  reactive

只有响应式变量才会自动更新,普通变量不会自动更新。

普通变量调用函数转为响应式变量

reactive只能包装对象,ref都可以包装

在js中,调用响应式对象的值的方式不同

案例效果

属性绑定

代码示例如下

图片属性前加 冒号   :

计数器加减案例

表单数据绑定

单项绑定,不推荐

只会把js的数据同步到页面,不会把页面同步到js

双向绑定

v-model 属性,绑定对象的id

计算属性

优势:缓存,只做一次字符串拼接

使用场景: 当一个值需要多次被调用时,使用这个函数

xhr基本使用

xhr上传数据

与fetch相比,xhr功能更强大

代码测试成功

Axios库使用

安装第三方库

安装好后可以在配置文件的依赖项中找到

实战案例

后端自己写的,前端学着写的

Onmounted()函数

页面组件加载完成后执行

全天总结

        今天的进度还可以,算是第一次真正用Vue进行了前后端代码的同时编写和测试,感觉很不错哈哈。但是Vue还不能结束掉,估计明天还得一天才行。尽可能明天就给它结束掉。加油。

Day--10        9.25

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

《粮油与饲料科技》是什么级别的期刊?是正规期刊吗?能评职称吗?

问题解答 问&#xff1a;《粮油与饲料科技》是不是核心期刊&#xff1f; 答&#xff1a;不是&#xff0c;是知网收录的第一批认定 学术期刊。 问&#xff1a;《粮油与饲料科技》级别&#xff1f; 答&#xff1a;省级。主管单位&#xff1a;中文天地出版传媒集团股份有限公司…

漏洞复现_永恒之蓝

1.概述 永恒之蓝&#xff08;EternalBlue&#xff09;是一个影响Windows操作系统的远程代码执行漏洞&#xff0c;编号为CVE-2017-0144&#xff0c;最初由美国国家安全局&#xff08;NSA&#xff09;开发并利用&#xff0c;后来被黑客组织Shadow Brokers泄露。该漏洞存在于SMBv…

Gitee Pipeline 从入门到实战【详细步骤】

文章目录 Gitee Pipeline 简介Gitee Pipeline 实战案例 1 - 前端部署输入源NPM 构建Docker 镜像构建Shell 命令执行案例 2 - 后端部署全局参数输入源Maven 构建Docker 镜像构建Shell 命令执行参考🚀 本文目标:快速了解 Gitee Pipeline,并实现前端及后端打包部署。 Gitee Pi…

【d46】【Java】【力扣】876.链表的中间结点

思路 先获得总体长度&#xff0c; 再得到中间节点 的索引&#xff0c;&#xff0c;这里的索引是从1开始的索引&#xff0c;而不是从0开始的索引(这种理解方式更简单) 排错&#xff1a;另一个思路&#xff1a;将链表都放进list&#xff0c;获得中间的数字&#xff0c;然后遍历…

AfuseKt1.3.6-10110功能强大的安卓网络视频播放器,支持多种在线存储和媒体管理平台!

AfuseKt 是一款功能强大的安卓网络视频播放器&#xff0c;专为满足用户对多样化媒体播放需求而设计。它不仅支持多种流行的在线存储和媒体管理平台&#xff0c;如阿里云盘、Alist、WebDAV和Emby等&#xff0c;还提供了刮削功能和海报墙展示&#xff0c;使得用户能够更加便捷地管…

船舶检测系统源码分享

船舶检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer Vision …

深度学习|误差逆传播:梯度速解

文章目录 引言链式法则误差逆传播加法的逆传播乘法的逆传播逆传播求梯度 SoftmaxWithLoss 层正向传播逆传播代码实现参考 结语 引言 我们知道训练神经网络模型的核心是以损失函数为基准来调整优化网络参数&#xff0c;使得网络的输出尽可能接近真实标签。在神经网络中&#xf…

网络原理(4)——网络层(IP)、数据链路层

1. IP 协议 基本概念&#xff1a; 主机&#xff1a;配有 IP 地址&#xff0c;但是不进行路由控制的设备 路由器&#xff1a;即配有 IP 地址&#xff0c;又能进行路由控制 节点&#xff1a;主机和路由器的统称 IP 协议报头格式 1) 4 位版本&#xff1a;实际上只有两个取值&…

RabbitMQ 高级特性——发送方确认

文章目录 前言发送方确认confirm 确认模式return 退回模式 常见面试题 前言 前面我们学习了 RabbitMQ 中交换机、队列和消息的持久化&#xff0c;这样能够保证存储在 RabbitMQ Broker 中的交换机和队列中的消息实现持久化&#xff0c;就算 RabbitMQ 服务发生了重启或者是宕机&…

安卓13去掉下拉菜单的Dump SysUI 堆的选项 android13删除Dump SysUI 堆

总纲 android13 rom 开发总纲说明 文章目录 1.前言2.问题分析3.代码分析3.1 位置13.2 位置24.代码修改5.编译6.彩蛋1.前言 客户需要去掉下拉菜单里面的Dump SysUI 堆图标,不让使用这个功能。 2.问题分析 android的下拉菜单在systemui里面,这里我们只需要定位到对应的添加代…

通义灵码AI 程序员正式发布:写代码谁还动手啊

虽然见不到面 但你已深潜我心 前几天&#xff0c;在 2024 年的杭州云栖大会上&#xff0c;随着通义大模型能力的全面提升&#xff0c;阿里云通义灵码这位中国的首位 AI 程序员也迎来重大的升级。 一年前这位 AI 程序员还只能完成基础的编程任务&#xff0c;到现在可以做到几…

2024年华为杯研究生数学建模竞赛D题(时空演化模型+脆性指数 完整文章|可视化)

2024年华为杯研究生数学建模竞赛D题 全文请从 底部名片 处加群获取哦~ 问题重述 题目背景&#xff1a; 地理系统是由自然和人文多要素综合作用形成的复杂巨系统。传统上&#xff0c;地理学家通过宏观结构和定性分析方法描述地理系统的主导特征&#xff0c;如地形分布、气候…

LabVIEW闪退

LabVIEW闪退或无法启动可能由多个原因引起&#xff0c;特别是在使用了一段时间后突然发生的问题。重启电脑后 LabVIEW 和所有 NI 软件都无法打开&#xff0c;甚至在卸载和重装时也没有反应。这种情况通常与系统环境、软件冲突或 NI 软件组件的损坏有关。 1. 检查系统和软件冲突…

使用 Docker 部署 RStudio 的终极教程

一.介绍 在现代数据科学和统计分析领域&#xff0c;RStudio 是一个广受欢迎的集成开发环境&#xff08;IDE&#xff09;&#xff0c;为用户提供了强大的工具来编写、调试和可视化 R 代码。然而&#xff0c;传统的 RStudio 安装可能面临环境配置复杂、版本兼容性等问题。Docker…

CentOS7搭建Hadoop3集群教程

一、集群环境说明 1、用VMware安装3台Centos7虚拟机 2、虚拟机配置&#xff1a;2C&#xff0c;2G内存&#xff0c;50G存储 3、集群架构设计 从表格中&#xff0c;可以看出&#xff0c;Hadoop集群&#xff0c;主要有2个模块服务&#xff0c;一个是HDFS服务&#xff0c;一个是YAR…

不靠学历,不拼年资,怎么才能月入2W?

之前统计局发布了《2023年城镇单位就业人员年平均工资情况》&#xff0c;2023年全国城镇非私营单位和私营单位就业人员年平均工资分别为120698元和68340元。也就是说在去年非私营单位就业人员平均月薪1W&#xff0c;而私营单位就业人员平均月薪只有5.7K左右。 图源&#xff1a;…

视频监控相关笔记

一、QT 之 QTreeWidget 树形控件 Qt编程指南&#xff0c;Qt新手教程&#xff0c;Qt Programming Guide 一个树形结构的节点中的图表文本 、附带数据的添加&#xff1a; QTreeWidgetItem* TourTreeWnd::InsertNode(NetNodeInfo node, QTreeWidgetItem* parent_item) { // …

asp.net core日志与异常处理小结

asp.net core的webApplicationBuilder中自带了一个日志组件,无需手动注册服务就能直接在控制器中构造注入&#xff0c;本文主要介绍了net core日志与异常处理小结&#xff0c;需要的朋友可以参考下 ILogger简单使用 asp.net core的webApplicationBuilder中自带了一个日志组件…

Redis的一些数据类型(一)

&#xff08;一&#xff09;数据类型 我们说redis是key value键值对的方式存储数据&#xff0c;key是字符串&#xff0c;而value是一些数据结构,那今天就来说一下value存储的数据。 我们数据结构包含&#xff0c;String&#xff0c;hash&#xff0c;list&#xff0c;set和zest但…

新手卖家做跨境电商,选择Shopee还是亚马逊?

对于刚刚涉足跨境电商领域的新人来说&#xff0c;选择合适的电商平台是迈出成功第一步的关键。目前最主流的跨境平台一定是亚马逊&#xff0c;平台覆盖全球各个市场&#xff0c;利润高&#xff0c;但门槛也高。Shopee主要面向的是东南亚市场&#xff0c;商品一般更有性价比&…