学习笔记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=1
              alert(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和false
          var flag = window.confirm();
      
          //定时器 setInterval  setTimeout
          
      location对象
      	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对象,给出管控区域以及data
    	new 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.mfbz.cn/a/273320.html

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

相关文章

园艺伴侣应用程序Plant-it

什么是 Plant-it &#xff1f; Plant-it 是一款园艺伴侣应用程序&#xff0c;可帮助您照顾植物。它不会建议您采取哪些操作&#xff0c;而是旨在记录您正在执行的活动。这是故意的&#xff0c;软件作者坚信&#xff0c;唯一负责知道何时给植物浇水、何时施肥等的人是你&#xf…

HBase深度历险 | 京东物流技术团队

简介 HBase 的全称是 Hadoop Database&#xff0c;是一个分布式的&#xff0c;可扩展&#xff0c;面向列簇的数据库&#xff0c;是一个通过大量廉价的机器解决海量数据的高速存储和读取的分布式数据库解决方案。本文会像剥洋葱一样&#xff0c;层层剥开她的心。 特点 首先我…

GaN HEMT的大信号(RF PA)性能

来源&#xff1a;Novel Drain-Connected Field Plate GaN HEMT Designs for Improved VBD −RON Tradeoff and RF PA Performance (IEEE TRANSACTIONS ON ELECTRON DEVICES) 使用 TCAD 提取的 I-V 和 C-V 曲线族&#xff0c;结合 Keysight 的 IC-CAP 器件建模套件和先进SPICE模…

工具系列:TimeGPT_(2)使用外生变量时间序列预测

文章目录 TimeGPT使用外生变量时间序列预测导入相关工具包预测欧美国家次日电力价格案例 TimeGPT使用外生变量时间序列预测 外生变量在时间序列预测中非常重要&#xff0c;因为它们提供了可能影响预测的额外信息。这些变量可以包括假日标记、营销支出、天气数据或与你正在预测…

JavaSE语法之十:抽象类(超全!!!)

文章目录 一、抽象类的概念二、抽象类的语法三、抽象类的特征四、抽象类的作用 一、抽象类的概念 在面向对象的概念中&#xff0c;所有的对象都是通过类来描绘的&#xff0c;但是反过来&#xff0c;并不是所有的类都是用来描绘对象的。 如果一个类没有包含足够的信息来描绘一个…

Postman接口测试(附教程)

前言 之前还没实际做过接口测试的时候呢&#xff0c;对接口测试这个概念比较渺茫&#xff0c;只能靠百度&#xff0c;查看各种接口实例&#xff0c;然后在工作中也没用上&#xff0c;现在呢是各种各样的接口都丢过来…

1. pytorch mnist 手写数字识别

文章目录 一、数据集介绍1.1、简介1.2 详细介绍1、数据量2、标注量3. 标注类别4.数据下载5.数据集解读 二、读取、加载数据集1、pytorch 自带库函数2、通过重构Dataset类读取特定的MNIST数据或者制作自己的MNIST数据集 三、模型构建四、 runtraintest评估模型的性能检查点的持续…

vue 导出 HTML 结构为 Word 文档(.docx)-支持表格、css样式、图片

在 Web 开发中&#xff0c;有时我们希望用户能够将网页上的 HTML 内容保存为 Word 文档&#xff0c;以便更方便地分享和打印。本文将介绍如何使用 html-docx-js 和 file-saver 这两个 JavaScript 库&#xff0c;实现将 HTML 结构导出为 Word 文档的功能。 工具简介 1. html-d…

智能优化算法应用:基于鱼鹰算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于鱼鹰算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于鱼鹰算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.鱼鹰算法4.实验参数设定5.算法结果6.参考文献7.MA…

楼宇对讲门铃的芯片选型分析

目前很多的高层住宅都使用了对讲门铃了&#xff0c;在频繁使用中&#xff0c;门铃会出现的越来越多种类&#xff0c;下面我就简单的介绍会有用到的几款芯片. 语音通话芯片&#xff1a;D34018,D34118,D5020,D31101; D34018 单片电话机通话电路&#xff0c;合并了必 需的放大器…

Android原生实现单选

六年前写的一个控件&#xff0c;一直没有时间总结&#xff0c;趁年底不怎么忙&#xff0c;整理一下之前写过的组件。供大家一起参考学习。废话不多说&#xff0c;先上图。 一、效果图 实现思路使用的是radioGroup加radiobutton组合方式。原理就是通过修改RadioButton 的backgr…

双向循环链表实现C语言关键字中英翻译机 ฅ( ̳• · • ̳ฅ)

目录 1.双向循环链表的声明与定义&#xff1a; 2. 创建链表并对节点中的数据赋初值 3. 插入节点并链接 4.中英翻译 5. 小游戏的实现 6.菜单的实现 7. 释放内存 8.在主函数中用刚才定义的函数实现各种代码 输入样例&#xff1a; 实现方法&#xff1a;双向循环链表来实…

7.7、kali linux环境下搭建DVWA

目录 一、资料下载准备工作 1.1、DVWA源代码下载 二、开启Apache、mysql服务 2.1、下载Apache2文件 2.2、开启Apache2服务 方法一&#xff1a;开启Apache2服务&#xff08;手动&#xff09; 方法二&#xff1a;开启Apache2服务&#xff08;系统自启动&#xff09; 2.3、…

基于springboot超市进销存系统

**&#x1f345;点赞收藏关注 → 私信领取本源代码、数据库&#x1f345; 本人在Java毕业设计领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目希望你能有所收获&#xff0c;少走一些弯路。&#x1f345;关注我不迷路&#x1f345;**摘要 随着信息化时代的到来&…

【数字孪生】数字工厂三维可视化大屏,智慧养殖三维可视化大屏,智慧农田三维可视化大屏,智慧运维三维可视化大屏,三维在线展示

个人主页&#xff1a; 左本Web3D&#xff0c;更多案例预览请点击》 在线案例 个人简介&#xff1a;专注Web3D使用ThreeJS实现3D效果技巧和学习案例 &#x1f495; &#x1f495;积跬步以至千里&#xff0c;致敬每个爱学习的你。喜欢的话请三连&#xff0c;有问题请私信或者加微…

通过MobaXterm远程连接Anolis

目录 前言&#xff1a; 一.设置ip 二.远程连接 前言&#xff1a; 小编已经阐述了如何安装Anolis系统&#xff0c;如果有不了解的小伙伴可以查看这一篇博客Anolis安装 这篇博客将会讲述如何远程连接Anolis系统。各位看官拿好板凳&#xff01; 一.设置ip 打开网卡所在位…

logstash收集华为、H3C、Cisco交换机日志

网络设备配置 将 syslog-ip 替换成服务器的IP地址。 Huawei info-center loghost source interface info-center loghost syslog-ip local-time facility local6 H3C info-center loghost source interface info-center loghost syslog-ip facility local5 Aruba logging arm …

Xcode 编译速度慢是什么原因?如何提高编译速度?

作为一个开发者&#xff0c;我们都希望能够高效地开发应用程序&#xff0c;而编译速度是影响开发效率的重要因素之一。然而&#xff0c;有时候我们会发现在使用 Xcode 进行开发时&#xff0c;译速度非常慢&#xff0c;这给我们带来了不少困扰。那么&#xff0c;为什么 Xcode 的…

用Ai制作一个镭射图标

下面来展示画一个镭射图标 1、首先画一个星型形状&#xff0c;然后去除描边&#xff0c;并施加渐变中的色谱 注意按住ctrl键拖动角点就可以改变尖角为圆角 按住ctrl键单击某一个角可得到某个角的圆角 选择渐变格式 径向渐变编辑渐变 把每个渐变颜色的饱和度S减半&#xff0c;…

Qt 中使用 MySQL 数据库保姆级教程(上)

作者&#xff1a;billy 版权声明&#xff1a;著作权归作者所有&#xff0c;商业转载请联系作者获得授权&#xff0c;非商业转载请注明出处 前言 在 Qt 中默认只搭载了 QSqlLite 数据库驱动&#xff0c;若要使用其他数据库需要自己下载数据库&#xff0c;并将数据库驱动加载到…
最新文章