学习笔记15——前端和http协议

学习笔记系列开头惯例发布一些寻亲消息,感谢关注!

链接:https://baobeihuijia.com/bbhj/

  • 关系

    • 客户端:对连接访问到的前端代码进行解析和渲染,就是浏览器的内核
    • 服务器端:按照规则编写前端界面代码
      • 解析标准就是Web标准
        • HTML:内容
        • CSS:外观
        • JavaScript:动态行为交互
  • 在这里插入图片描述

  • html:操作系统会将HTML文件默认被浏览器识别

    <html><head><title>快速</title></head><body><h1>photo</h1><img src="img/1.jpg" width="300" height="200"> <a href="www.csdn/" target="_self">新浪政务</a> > 正文# 水平分割线<hr></hr><span></span> 是没有语义的行组合标签</body>
    </html>
    
    • 表格

      在这里插入图片描述

    • 表单

      • 属性
        • action: 后台接收的地址
        • get: url后边拼接,url有长度限制
        • post:在消息体中传递,参数不限大小
      <body><form action="" method="get">name: <input type="text" name = "username">age: <input type="text" name="age"><input type="submit" value = "ok"></form>
      </body>
      
      • 表单项

        • input:

          在这里插入图片描述

        • select

          在这里插入图片描述

        • textarea

  • CSS

    • 格式

      • 行内样式:写在标签的style属性中

      • <h1 style = "xxx:xxx;xxx:xxx;">

      • 内嵌样式:写在html页面的head中

      • <style> h1{ xxx:xxx; } </style>

      • 外联样式:写在单独的css文件,通过link引入

    • css选择器:(id>class>元素)

      • 元素选择器 h1
      • class选择器(html中的class可以重复) .class
      • id选择器(html中的id不能重复) #id
  • JavaScript(探测页面行为,更好地动态交互体验)

    • js引入

      • 内部脚本

        <script>alert("hello js")
        </script>
        
      • 外部脚本

        <script src="js/demo.js"></script> alert("hello js")
        
    • JS基础

      // 输出语句
      window.alert(); 警告框
      document.write(); HTML页面输出
      console.log();浏览器控制台// var定义的变量是全局变量
      // var定义可以重复,会覆盖
      <script>   var a = 20;a = "张三";alert(a)
      </script>// let定义是一个局部变量
      // 不可以重复
      <script>   {let x=1alert(x)}
      </script>// const声明只读常量,值不能更改
      
    • 变量类型

      number
      string
      boolean
      null
      undefined (变量没被赋值,自动为undefined)var a = 20;
      typeof(a);==  类型不同,值同就为true
      === 类型和值都相同为true// 函数可以传递任意数量的参数
      // 函数定义一
      function add(a,b){return a+b;
      }
      var result = add(10,20);// 函数定义二
      var add = function(a,b){return a+b;
      }
      var result = add(10,20);
      
    • 数据类型

      • Array
      var arr = new Array(1,2,3,4);
      arr[2] = 3;arr.length
      foreach()仅遍历有值的元素
      push(7.8.9)
      // 从下标2开始删除两个
      splice(2,2)
      
      • String
      var str = new String("");
      var str = "";
      str.length
      str.charAt(3);// 获取索引位置为3的值
      str.indexOf("lo");// 检索字符串的位置
      var s = str.trim()//去除字符串左右空格
      str.subString(start,end); // 含头不含尾
      
      • js自定义对象
      var user = {name:"Tom",eat:function(){alert("json");}sleep(){alert("sleep");}
      };user.eat();
      user.name;
      
      • json
      var stu = '{"name":"tom","age":20,"addr":["beijing","shanghai"]}';// JSON转化为JS对象
      var jsObject = JSON.parse(stu);
      jsObject.name;//JS对象转为JSON字符串,即{"name":"tom","age":20,"addr":["beijing","shanghai"]}
      var jsonStr = JSON.stringify(jsObject);
      
      • BOM对象:与浏览器沟通
      window对象window.alert("xxxxx");//返回值是true和falsevar flag = window.confirm();//定时器 setInterval  setTimeoutlocation对象location.href //获取地址栏的url信息location.href = "www.baidu.com" // 会跳转到新的地址
      
      • DOM:将html语言各个组成部分封装为对象,从而实现页面修改
      # id获取对象
      var img = document.getElementById('img');# 标签获取对象
      var divs = document.getElementsByTagName('div');# 根据name属性获取对象
      var ins = document.getElementsByName('hobby');# 根据class属性获取对象
      var ins = document.getElementsByClassName('cls');# 举例,innerHTML可以识别html代码
      var ins = document.getElementsByName('hobby');
      for(let i=0;i<ins.length;i++){ins[i].innerHTML += "<font color='red'>very good</font>"
      }
      
    • 事件绑定

      在这里插入图片描述

      在这里插入图片描述

  • js的高级框架Vue(view和model之间传递和渲染的方法)

    1、链接到vue
    <script src="js/vue.js"></script>2、创建vue对象,给出管控区域以及datanew Vue({el:"#app",data:{url:"http://www.baidu.com"}})new Vue({el:"#app",data:{    },methods:{handle:function(){alert("点出来了");}}})
    3、<div id="app"># html组件绑定model中的数据用法<a :href="url">链接1</a><a v-bind:href="url">链接2</a># 表单组件绑定model中的数据用法<input type = "text" v-model = "url"></div>	<div id="app"># 表单组件绑定model中的函数用法<input type = "button" value="点击" v-on:click="handle()"></div>
    
  • Ajax(前后端交互get/post)

    • 数据交互:ajax可以给服务器发送请求,获得服务器响应的数据
    • 异步交互:不刷新页面,与服务器交换数据并更新部分页面
    • Axios(ajax的封装和简化)
      • 在这里插入图片描述
  • Vue标准化开发环境 vue-cli需要下载,就会初始化一个前端框架

    • main.js
    • App.Vue(引用自己写的的vue)
    • 自己的vue:三层架构:template/script/style
    • Vue组件库Element:先找到布局确定整体大小,然后找组件直接赋值粘贴到自己的vue中即可
    • 项目目录下安装axios,然后import axios就可以实现异步交互
    • Vue可以通过route重定向
  • Nginx

    • Nginx详解(一文带你搞懂Nginx)-CSDN博客

    • Nginx:动静分离(示意图+配置讲解)-CSDN博客

      • 反向代理
        • 负载均衡
          • 轮询法(默认方法)
          • weight权重模式(加权轮询)
          • ip_hash
        • 动静分离
  • Http协议

  • 基于TCP协议:三次握手

  • 一次请求一次响应,不同请求之间数据不共享

    • 请求数据格式

      • 请求行(请求方式、资源路径、协议以及版本号)
      • 请求头:请求路径以及浏览器版本号
      • 请求体:post的请求参数
    • get和post请求的区别:get参数会写在资源路径,没有请求体,post会写在请求体中

    • 响应数据格式

      • 响应行(协议、状态码、描述)200 OK
      • 响应头:响应数据的类型;响应数据的长度;采用的压缩算法;客户端的缓存时间;cookie
      • 响应体:响应数据给到前端
    • 解析协议:按照字符串格式解析即可

  • Tomcat工作原理:搜下边这篇

  • 在这里插入图片描述

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

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

相关文章

Mysql 高级语句

目录 高阶查询select语句&#xff1a; 显示表格中一个或数个字段的所有数据记录&#xff1a; 不显示重复的数据记录&#xff1a;distinct and且&#xff0c;or或 显示已知的值的数据记录&#xff1a;in 显示两个值范围内的数据记录&#xff1a;between 通配符&#xff1…

UE蓝图 RPG动作游戏(一) day15

角色状态制作 制作角色动画混合空间 创建一个动混合空间 添加动作在混合空间 动画蓝图 创建一个动画蓝图 先使用混合空间进行移动&#xff0c;后续优化后再使用状态机 编写垂直水平速度逻辑初始化&#xff0c;获取到此动画的角色组件 获取Horizontal与Vertical的速度逻辑 …

CDH 6.3.2集成flink 1.18 zookeeper版本不匹配Flink-yarn启动失败

CDH 6.3.2集成flink 1.18 zookeeper版本不匹配Flink-yarn不能正常启动&#xff0c;而在CHD Web页面&#xff0c;flink日志报错提示不明确&#xff0c;不能定位具体错误。CM WEB启动失败错误日志如下图所示&#xff1a; CM查看完成错误日志 [31/Dec/2023 10:45:09 0000] 26000…

osg::DrawElements*系列函数及GL_QUAD_STRIP、GL_QUADS绘制四边形效率对比

目录 1. 前言 2. osg::DrawElements*系列函数用法说明 3. GL_QUADS、GL_QUAD_STRIP用法及不同点 4. 效率对比 5. 总结 6. 参考资料 1. 前言 利用osg绘制图元&#xff0c;如&#xff1a;三角形、四边形等&#xff0c;一般用osg::PrimitiveSet类。其派生出了很多子类&#…

使用docker build构建image

文章目录 环境步骤准备例1&#xff1a;基本用法例2&#xff1a;缓存layer例3&#xff1a;Multi-stage例4&#xff1a;Mountcache mountbind mount 例5&#xff1a;参数例6&#xff1a;Export文件例7&#xff1a;测试 参考 环境 RHEL 9.3Docker Community 24.0.7 步骤 在Dock…

Cookie、Session

一、会话管理 1、什么是会话&#xff1f; 会话是客户端和服务端之间进行多次的请求和响应。 相当于两个人聊天&#xff0c;进行了多次的问答。 对多次问答的管理叫做会话管理&#xff0c;管理的东西是通信状态。 2、什么是状态&#xff1f; 举例&#xff1a; 小明去校园食堂…

常用设计模式全面总结版(JavaKotlin)

这篇文章主要是针对之前博客的下列文章的总结版本: 《设计模式系列学习笔记》《Kotlin核心编程》笔记:设计模式【Android知识笔记】FrameWork中的设计模式主要为了在学习了 Kotlin 之后,将 Java 的设计模式实现与 Kotin 的实现放在一起做一个对比。 一、创建型模式 单例模…

以太网二层交换机实验

实验目的&#xff1a; &#xff08;1&#xff09;理解二层交换机的原理及工作方式&#xff1b; &#xff08;2&#xff09;利用交换机组建小型交换式局域网。 实验器材&#xff1a; Cisco packet 实验内容&#xff1a; 本实验可用一台主机去ping另一台主机&#xff0c;并…

Baumer工业相机堡盟工业相机如何通过NEOAPI SDK设置相机的图像剪切(ROI)功能(C++)

Baumer工业相机堡盟工业相机如何通过NEOAPI SDK设置相机的图像剪切&#xff08;ROI&#xff09;功能&#xff08;C&#xff09; Baumer工业相机Baumer工业相机的图像剪切&#xff08;ROI&#xff09;功能的技术背景CameraExplorer如何使用图像剪切&#xff08;ROI&#xff09;功…

Python武器库开发-武器库篇之Git的分支使用(三十九)

武器库篇之Git的分支使用(三十九) Git分支是一种用于在项目中并行开发和管理代码的功能。分支允许开发人员在不干扰主要代码的情况下创建新的代码版本&#xff0c;以便尝试新功能、修复错误或独立开发功能。一般正常情况下&#xff0c;开发人员开发一个软件&#xff0c;会有两…

HarmonyOS4.0系统性深入开发07创建一个ArkTS卡片

创建一个ArkTS卡片 在已有的应用工程中&#xff0c;创建ArkTS卡片&#xff0c;具体操作方式如下。 创建卡片。 根据实际业务场景&#xff0c;选择一个卡片模板。 在选择卡片的开发语言类型&#xff08;Language&#xff09;时&#xff0c;选择ArkTS选项&#xff0c;然后单…

nodejs+vue+微信小程序+python+PHP技术的健康信息网站-计算机毕业设计推荐

3.2 功能性需求分析 健康信息网站为会员提供健康信息服务的系统&#xff0c;管理员通过登录系统&#xff0c;管理会员信息、健康咨询、健康知识、健康档案、健康养生、健康信息的搜索、健康资讯等。需要学习的会员浏览健康信息网站&#xff0c;查询所有的健康信息&#xff0c;可…

【Java EE初阶三 】线程的状态与安全(下)

3. 线程安全 线程安全&#xff1a;某个代码&#xff0c;不管它是单个线程执行&#xff0c;还是多个线程执行&#xff0c;都不会产生bug&#xff0c;这个情况就成为“线程安全”。 线程不安全&#xff1a;某个代码&#xff0c;它单个线程执行&#xff0c;不会产生bug&#xff0c…

七:Day01_Java9—16新特性

第一章 JDK9 新特性 jdk9是新特性最多的&#xff0c;因为jdk8是一个稳定版本。 1、JDK9新特性概述 模块系统 &#xff08;Module System&#xff09; Java9最大特性。它提供了类似于OSGI框架的功能&#xff0c;模块之间存在相互的依赖关系&#xff0c;可以导出一个公共的API…

YOLOv8改进 | 2023注意力篇 | iRMB倒置残差块注意力机制(轻量化注意力机制)

一、本文介绍 本文给家大家带来的改进机制是iRMB&#xff0c;其是在论文Rethinking Mobile Block for Efficient Attention-based Models种提出&#xff0c;论文提出了一个新的主干网络EMO(后面我也会教大家如何使用该主干&#xff0c;本文先教大家使用该文中提出的注意力机制…

【Java进阶篇】什么是UUID,能不能保证唯一?

什么是UUID&#xff0c;能不能保证唯一? ✔️典型解析✔️优缺点 ✔️各个版本实现✔️V1.基于时间戳的UUID✔️V2.DCE(Distributed Computing Environment)安全的UUID✔️V3.基于名称空间的UUID(MD5)✔️V4.基于随机数的UUID✔️V5.基于名称空间的UUID(SHA1)✔️各个版本总结…

学生管理系统(vue + springboot)

学生管理系统&#xff08;vuespringboot&#xff09;资源-CSDN文库 项目介绍 这是一个采用前后端分离开发的项目&#xff0c;前端采用 Vue 开发、后端采用 Spring boot Mybatis 开发。 项目部署 ⭐️如果你有 docker 的话&#xff0c;直接 docker compose up 即可启动&#…

SpringBoot入门指南(学习笔记)

概述 Springboot是Spring的一个子项目&#xff0c;用于快速构建Spring应用程序 入门 ①创建SpringBoot工程 ②编写Controller RestController public class HelloContoller {RequestMapping("/hello")public String hello() {return "hello";} }③运行…

golang锁源码【只有关键逻辑】

条件锁 type Cond struct {L Lockernotify notifyList } type notifyList struct {wait uint32 //表示当前 Wait 的最大 ticket 值notify uint32 //表示目前已唤醒的 goroutine 的 ticket 的最大值lock uintptr // key field of the mutexhead unsafe.Pointer //链表头…

论文解读:Coordinate Attention for Efficient Mobile Network Design(CVPR2021)

论文前言 原理其实很简单&#xff0c;但是论文作者说得很抽象&#xff0c;时间紧的建议直接看3.1中原理简述CBMA、原理简述CBMA以及3.2中原理简述coordinate attention block即可。 Abstract 最近关于mobile network设计的研究已经证明了通道注意(例如&#xff0c;the Squee…