java Web学习笔记(三)

news2024/12/26 11:30:00

文章目录

    • 1. 前置知识
    • 2. Vue
      • 使用vite构建项目
      • SFC入门
      • 使用ref和.value体会响应式数据(使用ES6和setup)
    • 3. Vue视图渲染技术及其语法
      • 模板语法:命令
        • 插值表达式
        • 渲染双标`><`中的文本(还挺可爱)
        • 属性渲染命令
        • 事件渲染命令
      • 响应式基础
        • 响应式数据
      • 两个渲染
        • 条件渲染
        • 列表渲染
      • 数据的双向绑定
      • 属性计算(不常用)
      • 重新回顾SFC(组件传参)
        • 文件目录结构(涉及多个vue文件)
    • 4. 路由机制(router)
      • 路由的使用
      • 路由接收参数
      • 路由守卫
    • 5. vue3数据交互 axios(处理异步请求)
      • 前置学习:promise
        • 特点
        • promise在html中的用法(后面有更简洁的)
        • asyc声明回调函数
      • axios简介
      • axios的使用

1. 前置知识

前置知识

2. Vue

vue的核心功能:声明式渲染响应性

渐进式框架vue 理解:功能逐步完善的过程

声明式渲染:Vue扩充了html语法使其能够声明式响应js

响应性:在改变js代码的同时html组件的内容自动改变,不需要使用按钮等组件手动触发文本改变

使用vite构建项目

  1. 以管理员身份打开vscode

如果不以管理员身份打开vscode,将会导致不能再vscode使用终端访问npm命令

  1. 输入命令(第一次进入会下载vite库)
npm create vite
  1. 根据提示修改项目名、选择框架和语言

这里是vue框架和JavaScript语言

  • 然后会在命令行的目录下创建相对应的工程
  1. 进入项目目录,然后下载依赖
cd ***# 你自己的项目名
npm install  # npm i
  1. 运行项目
npm run dev # 以测试环境启动项目(在package.json中自定义)
  1. 停止项目
ctrl + c

工程文件讲解:不可能给你讲的,先多练,练多了才一讲就通

SFC入门

SFC是Vue的一种规范(Single-File Component):

vue里面含有前端三件套的语法,然后html通过ES6语法导入.vue文件实现前端页面的显示。(导入方式见前置知识)

.vue文件

  • template标签 代表组件的html部分代码 代替传统的.html文件
  • script标签 代表组件的js代码 代替传统的.js文件
  • style标签 代表组件的css样式代码 代替传统的.css文件

标准的.vue文件格式

<script setup>
</script>

<template>
</template>

<style scoped>
</style>

按照.vue文件可以看出style是管理css(样式)的;script是管理js的

当然也可以在对应的标签中导入样式:

<script setup>
import './style/test.css'
</script>
...
<style scoped>
  @import './style/test.css'
</style>

注意:导入全局的样式文件,在工程的main.js文件中导入即可

使用ref和.value体会响应式数据(使用ES6和setup)

<!-- 使用ES6语法实现 -->
<script type="module">
  import {ref,reactive} from 'vue'

  export default {
    setup(){
      let counter = ref(1)
      
      function counterUp(){
        counter.value ++
      }

      function counterDown(){
        counter.value --
      }

      return {
        counter,
        counterUp,
        counterDown
      }
    }
  }
</script>

<template>
  <div>
    <button @click="counterUp()">+</button>
      <span v-text="counter"></span>
    <button @click="counterDown()">-</button>
  </div>
</template>

<style scoped>

</style>
<!-- 在script中声明setup实现 -->
<script setup>
  import {ref,reactive} from 'vue'

  let counter = ref(1)
  function counterUp(){
    counter.value ++
  }

  function counterDown(){
    counter.value --
  }
</script>

<template>
  <div>
    <button @click="counterUp()">+</button>
      <span v-text="counter"></span>
    <button @click="counterDown()">-</button>
  </div>
</template>

<style scoped>

</style>

总结:在script中使用setup声明的优点,声明即存在,因为存在和代码冗余,不需要返回数据类型或方法

3. Vue视图渲染技术及其语法

模板语法:命令

删除原本的vue3默认样式设置:

  1. 删除components文件夹中的.vue文件
  2. 删除main.js中的全局样式文件
  3. 删除App.vue中的三个主标签中的所有内容
插值表达式

语法

插值表达式语法:
{{数据名字、函数名、对象调用API}}

如果调用的数据的名字,则将名字渲染到对应的位置

如果调用的事函数名,则将函数返回值渲染到对应的位置

可以在双大括号中传入对象,同时调用相对应的API

<script setup>
   // 准备
  let msg = "hello world"
  let getMsg=()=>{
    return "hello world222"
  }
  let age = 16
  let bee = "蜜蜂 嗡嗡"
  let carts = [{name:"可乐",price:3,number:6},{name:"薯片",price:1.5,number:8}]

  function priceAll(){
    let count = 0
    // 在前端的增强for循环第一个定义的不是数组对象,而是数组的第几个
    for(let index in carts){
      count += carts[index].price*carts[index].number
    }
    return count
  }
</script>
<template>
  <!--示例-->
  <div>
    <h1>{{msg}}</h1>
  </div>
  msg 标签的额值为:{{getMsg()}}<br>
  年龄:{{ age }} 是否成年?{{ age > 18 ? "是": "否" }}<br>
  {{bee.split(' ').reverse().join('')}}<br>
  {{ priceAll() }}
</template>
渲染双标><中的文本(还挺可爱)

v-text和v-html语法:

v-text不支持html的标签识别,直接展示html标签的文本

v-html支持识别html的标签

<!--测试准备-->
<script setup>
  let msg = "hello world"
  // 命令支持模板字符串
  let ddd = "die"
  let msg2 = `nobody will ${ddd}`
  let age = 19
  let bee = '蜜 蜂'
</script>

<!--测试-->
<template>
  <h1 v-text="msg"></h1>
  <h1 v-text="msg2"></h1>
  <h1 v-text="`you will ${ddd}`"></h1>
  <h1 v-text="age>=18?'成年':'未成年'"></h1>
  <h1 v-text="bee.split(' ').reverse().join('')"></h1>
</template>
属性渲染命令

v-bind语法:

v-bind支持识别""中的变量

v-bind:属性名 可以简写为 :属性名

<!--测试准备-->
<script setup>
  const data={
    logo:"https://s21.ax1x.com/2024/07/11/pkhhICn.md.jpg",
    name:"linus",
    url:"https://www.bilibili.com/"
  }

  let urlTest = "https://s21.ax1x.com/2024/07/11/pkhhICn.md.jpg"
</script>

<!--测试-->
<template>
  <div>
    <a v-bind:href="data.url">
      <img v-bind:src="data.logo" :title="data.name">
    </a>
  </div>
</template>
事件渲染命令

v-on 语法

v-on:事件名可以简写为 @事件名

写法区别:

jsvue
onclickclick
ondbclickdbclick
onblurblur
onfocusfocus
<!--测试准备-->
<script setup>
  import {ref} from 'vue';


  function fun1(){
    alert("hi")
  }

  let counter = ref(1)

  function fun2(){
    counter.value ++
  }
</script>

<!--测试-->
<template>
  <button v-on:click="fun1()">hello</button>
  <button @click="fun1()">hello</button>    <br>

  <!--内联事件-->
  <button v-on:click="fun2()">+</button>
  {{ counter }} <br>
  <button v-on:click="counter ++">+</button>
  {{ counter }} <br>

  <!--事件的修饰符-->
  <button v-on:click.once="fun2()">+</button>
  {{ counter }} (这个加号只能使用一次)<br>

  <!-- 组件原始的默认行为是否执行prevent修饰符 -->
</template>

响应式基础

响应式数据

将数据转换为响应式数据

两种方式:ref 、 reactive

ref方式:一般用于将数据转换为响应式数据

reactive方式:一般用于将对象转换为响应式数据

使用前都需要导包:import{ref,reactive} from "vue"

<!--测试准备-->
<script setup>
import{ref,reactive} from "vue"
  let counter = ref(10)
  let person = reactive({
    name:"",
    age:12
  })
  function fun1(){
    counter.value ++
  }
  function fun2(){
    person.age ++
  }
</script>

<!--测试-->
<template>
    <button v-on:click="fun1()">+</button>
    {{ counter }}
    <button v-on:click="fun2()">+</button>
    {{ person.age }}
</template>

两个渲染

条件渲染

当符合某一特定条件之后再对数据进行渲染

v-if命令:如果当前表达式为true,渲染当前元素,否则不渲染

v-else命令:自动和前一个v-if做取反操作

v-show命令:也可以使组件不展示,但是方式是通过css隐藏;而不是像v-if一样直接让页面不对其进行渲染

<!--测试准备-->
<script setup>
import {ref} from "vue"
  let flag = ref(true)
</script>
<!--测试-->
<template>
  <div>
    <h1 id="h1" v-if="flag">vue is easy</h1>
    <h1 id="h2" v-else>vue is not easy</h1>
    <button @click="flag = !flag">toggle</button>
  </div>  
</template>
列表渲染

列表渲染

v-for:与li标签绑定,

<!--测试准备-->
<script setup>
    import {reactive} from "vue"

    let items = reactive([
        {
            id:"item1",
            message:"可乐"
        },
        {
            id:"item2",
            message:"薯片"
        },
        {
            id:"item3",
            message:"炸鸡"
        },
    ])
</script>

<!--测试-->
<template>
    <div>
        <ul>
            <li v-for="item in items">{{ item.message }}</li>
        </ul>
    </div>
</template>

数据的双向绑定

单向绑定:改变js中的数据的值会响应式地影响dom树中的数据。但是如果用户修改界面(html)中的数据,js中的数据不会改变

双向绑定:

使用: v-model=“数据”

顺便回顾html中的组件属性

<!--测试准备-->
<script setup>
    import {reactive} from "vue"

    let user = reactive({
        username:"",
        userPwd:"",
        habbits:[],
        love:[],
        introduct:"",
        province:[],
        local:""
    })

    function clearF(){
        user.username='',
        user.habbits.splice(0,user.habbits.length),
        user.userPwd='',
        user.love='',
        user.introduct='',
        user.province='',
        user.local=''
    }
</script>
<!--测试-->
<template>
    <div>
        <input type="text" v-model="user.username"><br>
        <input type="password" v-model="user.userPwd"><br>
        {{ user }} <br>
		<br>
        爱好<br>
            唱 <input type="checkbox" v-model="user.habbits" value="sing"><br>
            跳 <input type="checkbox" v-model="user.habbits" value="dance"><br>
            rap <input type="checkbox" v-model="user.habbits" value="rap"><br>
            篮球 <input type="checkbox" v-model="user.habbits" value="ball"><br>
		<br>
        性趣<br>
            女 <input type="radio" v-model="user.love" value="woman"><br>
            男 <input type="radio" v-model="user.love" value="man"><br>
		<br>
        简介<br>
            <textarea v-model="user.introduct"></textarea>
		<br>
        籍贯<br>
            <select v-model="user.local">
                <option value="1">11</option>
                <option value="2">22</option>
                <option value="3">33</option>
            </select><br>
            <button @click="clearF()">清空</button>
    </div>
</template>

属性计算(不常用)

<!--测试准备-->
<script setup>
    import {reactive,computed} from "vue"

    const author = reactive({
        name:"张三",
        books:["前端","后端","数据库"]

    })

    // 每次调用都会重新计算
    function fun1(){
        return author.books.length>0?"是":"否"
    }

    // 每次调用都会检查是否和上次调用的数据相同
    let bookNum = computed(()=>{return author.books.length>0?"是":"否"})
</script>

<!--测试-->
<template>
    <div>
        <p>作者:{{ author.name }}</p>
        是否出版过图书:{{ fun1() }}  <br>
        是否出版过图书:{{ bookNum }}
    </div>
</template>

重新回顾SFC(组件传参)

测试组件拼接页面小练习以及组件之间参数的传递

文件目录结构(涉及多个vue文件)

pk4VXeP.png

<!--Content.vue-->
<script setup>
  import {defineProps} from 'vue'

  defineProps({
    message:String
  })
</script>

<template>
  <div>
    这里是展示主要内容
    <h1>{{ message }}</h1>
  </div>
</template>

<style scoped>
</style>

<!--Header.vue-->
<script setup>

</script>

<template>
  <div>
    欢迎:光临  <a href="#">退出登陆</a>
  </div>
</template>

<style scoped>
</style>

<!--Navigater.vue-->
<script setup>
  // 定义向父组件提交数据的事件和提交数据
  import { defineEmits } from 'vue';
  // 定义广播对象
  const emits = defineEmits(["sendMenu"])

  function send(data){
    // 键值对方式提交数据
    emits("sendMenu",data)
  }
</script>

<template>
  <div>
    <ul>
      <li @click="send('学员管理')">学员管理</li>
      <li @click="send('图书管理')">图书管理</li>
      <li @click="send('请假管理')">请假管理</li>
      <li @click="send('考试管理')">考试管理</li>
      <li @click="send('班级管理')">班级管理</li>
      <li @click="send('教师管理')">教师管理</li>
    </ul>
  </div>
</template>

<style scoped>
</style>

<!--App.vue-->
<script setup>
import {ref} from 'vue'
import Header from './components/Header.vue'
import Navigater from './components/Navigater.vue'
import Content from './components/Content.vue'
  let menu = ref("")

  // 接受数据的方法
  function recevier(data){
    menu.value = data
  }
</script>

  
<template>
  <div>
    <Header class="head"></Header>
    <Navigater @sendMenu="recevier" class="navigater"></Navigater>
    <Content class="content" v-bind:message="menu"></Content>
    <h1>{{ menu }}</h1>
  </div>
</template>

<style scoped>

  .head{
    height: 80px;
    border: 1px solid red;
  }
  .navigater{
    width: 15%;
    height: 500px;
    border: 1px solid green;
    float: left;
  }
  .content{
    width: 83%;
    height:500px;
    border: 1px solid yellow;
    float: right;
  }
</style>

4. 路由机制(router)

引入路由的目的:实现页面的切换

路由切换页面的实现方式:通过改变申请的url实现页面的切换

路由的使用

  1. 使用vite创建前端工程

  2. 下载路由相关依赖

npm install vue-router
  1. 修改main.js配置router
import { createApp } from 'vue'
import App from './App.vue'

import router from './routers/router'

const app = createApp(App)

app.use(router)
app.mount('#app')
  1. 在主vue页面添加<router-view>标签
<template>
  <div>

    <!--router-link标签可以在子页面中使用-->
    <router-link to="/home">home页</router-link>     <br>
    <router-link to="/list">list页</router-link>     <br>
    <router-link to="/add">add页</router-link>       <br>
    <router-link to="/update">update页</router-link> <br>

    <!--一定要在需要轮播的主页面上添加router-view标签-->
    <router-view></router-view>
    
  </div>
</template>
  1. 配置路由的映射路径
/*导入创建路由对象需要使用的函数*/
import {createRouter,createWebHashHistory} from 'vue-router'

// 导入.vue组件
import Home from "../components/Home.vue"
import List from "../components/List.vue"
import Add from "../components/Add.vue"
import Update from "../components/Update.vue"

//创建一个路由对象
const router =createRouter({
    //history属性用于记录路由的历史
    history : createWebHashHistory(),
    // 定义路径和组件之间的对应关系
    routes:[
        {
            path:"/home",
            component:Home
        },
        {
            path:"/list",
            component:List
        },
        {
            path:"/add",
            component:Add
        },
        {
            path:"/update",
            component:Update
        },
        {
            path:"/",
            component:Home
        },
        // 重定向
        {
            path:"/showAll",
            redirect:"list"
        }
    ]
})
//向外暴露router
export default router
  1. 定义各个页面的信息

……

注意:

5.的映射路径中如果要指定映射到哪一个名字的router-view组件,可以采用如下写法

routes:[{
        path:"/home",
        component{
            homeView:Home
        // router-view名:子页面别名
        }
    }]

注意:

也可以不是单纯使用router-vue包中的接口,也可以设置方法来控制路由

<!--准备-->
<script setup>
  import {useRouter} from 'vue-router'
  const router = useRouter()
  
  function showList(){
    router.push("/list")
  }
</script>
  
<!--测试-->
<template>
  <div>
    <!--router-link标签可以在子页面中使用-->
    <router-link to="/home">home页</router-link>     <br>
    <router-link to="/list">list页</router-link>     <br>
    <router-link to="/add">add页</router-link>       <br>
    <router-link to="/update">update页</router-link> <br>
    <button @click="showList()">list</button>
    <!--一定要在需要轮播的主页面上添加router-view标签-->
    <router-view></router-view>
  </div>

路由接收参数

路由守卫

页面跳转前后的代码逻辑

操作:略

5. vue3数据交互 axios(处理异步请求)

axios是原生代替Ajax的解决方案

前置学习:promise

特点
  1. 只有三种状态:进行中、成功、失败
  2. 一旦改变,不会再次改变
promise在html中的用法(后面有更简洁的)
<script>
    let promise =new Promise(function(resolve,reject){
        console.log("promise do some code ... ...")
        //resolve("promise success")
        reject("promise fail")
    })
    console.log('other code1111 invoked')
    //2.获取回调函数结果  then在这里会等待promise中的运行结果,但是不会阻塞代码继续运行
    promise.then(
        // 成功时
        function(value){console.log(`promise中执行了resolve:${value}`)},
        // 失败时
        function(error){console.log(`promise中执行了reject:${error}`)}
    )
    // 3 其他代码执行   
    console.log('other code2222 invoked')
</script>
asyc声明回调函数
<script>
	async function fun1(){}
</script>

axios简介

axios是vue封装好的专门用于发送Ajax请求的API包

axios的使用

<script setup>
    import axios from "axios"
    import {ref,reactive} from "vue"

    // 这个变量作用域一定要大!
    let message = reactive({
        "code":1,
        "content":"hahaha"
    })

    function getLoveWords(){
        // return axios({
        //     method:"post",
        //     url:"https://api.uomg.com/api/rand.qinghua?format=json",
        //     data:{          
        //     },
        //     params:{
        //         format:'json',
        //         username:"张三"
        //     }
        // })
        return axios.get("https://api.uomg.com/api/rand.qinghua?format=json?format=json")
    }

    async function getNews(){
        // let response = await getLoveWords()
        let {data} = await getLoveWords()

        // Object.assign(message,response.data)
        Object.assign(message,data)
    }
</script>

还有一个拦截器,大概和后端的拦截器差不多吧,就这样了,今天学习的劲头真糟糕。

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

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

相关文章

php安装Imagick扩展 处理pdf为图片

这个方法是使用源码编译安装&#xff0c;适用于php编译安装和包安装。如果有pecl&#xff0c;直接安装就行&#xff0c;我这是因为多个环境怕直接使用pecl工具导致混乱。 由于浏览器显示大量pdf不方便&#xff0c;我这先将pdf转化为图片再显示 如果没有安装php&#xff0c;这是…

智能家居装修怎么布线?智能家居网络与开关插座布置

打造全屋智能家居。计划的智能家居方案以米家系列为主&#xff0c;智能家居联网方案以无线为主。装修前为了装备智能家居做了很多准备工作&#xff0c;本文深圳侨杰智能分享一个智能家居装修和布线方面的心得与实战知识。希望能对大家的装修有所帮助。 ​1.关于网络 如果房子比…

春招冲刺百题计划|堆

Java基础复习 Java数组的声明与初始化Java ArrayListJava HashMapJava String 类Java LinkedListJava Deque继承LinkedListJava SetJava 队列优先队列:第二题用到了 第一题&#xff1a;215. 数组中的第K个最大元素 可以直接使用Arrays.sort()快排&#xff0c;然后return nums…

数据库第六次

视图 salary decimal(10,2) not null default 0 comment ‘工资’, address varchar(200) not null default ‘’ comment ‘通讯地址’, dept_id int comment ‘部门编号’ ); create index idx_name on emp(emp_name); create index idx_birth on emp(birth); create index…

MySQL-日志-优化

目录 介绍一下mysql 的日志 redo log 和binlog 的区别及应用场景 redo log 和 binlog 在恢复数据库有什么区别? redo log 是怎么实现持久化的? redo log除了崩溃恢复还有什么其他作用? &#xff08;顺序写&#xff09; redo log 怎么刷入磁盘的知道吗&#xff1f; 两阶…

2024西安铁一中集训DAY2 ---- 模拟赛(最小生成树 + AC自动机 + 模拟 + rmq)

文章目录 比赛成绩题解A. 江桥的生成树&#xff08;MST&#xff09;B. 江桥的神秘密码&#xff08;AC自动机&#xff0c;ST表&#xff09;C. 江桥的字符距离D. 江桥的防御力测试&#xff08;rmq&#xff0c;乱搞&#xff09; 比赛成绩 估测&#xff1a;60 100 100 0 260 实…

FastAPI 学习之路(四十九)WebSockets(五)修复接口测试中的问题

其实代码没有问题&#xff0c;但是我们忽略了一个问题&#xff0c;就是在正常的开发中&#xff0c;肯定是遇到过这样的情况&#xff0c;我们频繁的有客户端链接&#xff0c;断开连接&#xff0c;需要统一的管理这些链接&#xff0c;那么应该如何管理呢。其实可以声明一个类去管…

218.贪心算法:分发糖果(力扣)

核心思想 初始化每个学生的糖果数为1&#xff1a; 确保每个学生至少有一颗糖果。从左到右遍历&#xff1a; 如果当前学生的评分高于前一个学生&#xff0c;则当前学生的糖果数应比前一个学生多一颗。从右到左遍历&#xff1a; 如果当前学生的评分高于后一个学生&#xff0c;则…

01对话系统---文字渐出和停顿效果

实现代码 using System.Collections; using System.Collections.Generic; using UnityEngine; using TMPro; using System.Text.RegularExpressions; using System;/// <summary> /// 增加文本时间停顿功能 /// 增加文字渐出&#xff0c;&#xff08;单个字符逐渐显现&a…

Unity免费领场景多人实时协作地编2人版局域网和LAN联机类似谷歌文档协同合作搭建场景同步资产设置编辑付费版支持10人甚至更多20240709

大家有没有用过谷歌文档、石墨文档、飞书文档等等之类的协同工具呢&#xff1f; Blender也有类似多人联机建模的插件&#xff0c; Unity也有类似的多人合作搭建场景的插件啦。 刚找到一款免费插件&#xff0c;可以支持2人局域网和LAN联机地编。 付费的版本支持组建更大的团队。…

从汇编层看64位程序运行——静态分析和动态分析入门

大纲 GDBIDA总结参考资料 之前一直谈各种相对宏观的工具怎么使用&#xff0c;比如Flink、RabbitMQ等。最近想聊聊比较微观的技术&#xff0c;用各种“显微镜”去看看运行在系统层的二进制码是什么样子。当然二进制码比较难以记忆&#xff0c;于是我会从二进制码的助记符——汇编…

IOS上微信小程序密码框光标离开提示存储密码解决方案

问题&#xff1a; ios密码框输入密码光标离开之后会提示存储密码的弹窗 解决方案 1、在苹果手机上面把 “自动填充密码”关闭&#xff0c;但是苹果这个默认开启&#xff0c;而且大部分客户也不会去自己关闭。 2、欺骗苹果手机&#xff0c;代码实现。 先说解决思路&#xf…

java内部类的本质

定义在类内部&#xff0c;可以实现对外部完全隐藏&#xff0c;可以有更好的封装性&#xff0c;代码实现上也往往更为简洁。 内部类可以方便地访问外部类的私有变量&#xff0c;可以声明为private从而实现对外完全隐藏。 在Java中&#xff0c;根据定义的位置和方式不同&#xf…

mmaction2的GPU环境配置记录RTX3090,cuda12.2,ubuntu22.04版本

1、配置镜像源 最重要的一个步骤,先看下镜像源地址,如果镜像源有问题,所有的包安装都会有问题 镜像源地址获取地址:选择对应的ubuntu版本号,将里面的镜像源地址复制出来,更新到服务器 ubuntu | 镜像站使用帮助 | 清华大学开源软件镜像站 | Tsinghua Open Source Mirro…

【web]-sql注入-bestdb

打开页面后&#xff0c;如图 查看源代码&#xff0c;发现有段注释&#xff0c;尝试sql注入 <!-- $sql "SELECT * FROM users WHERE id $query OR username \"$query\"";--> 1、尝试万能密码 1 or 11# / admin&#xff0c; 提示F…

Linux磁盘-MBRGPT

作者介绍&#xff1a;简历上没有一个精通的运维工程师。希望大家多多关注作者&#xff0c;下面的思维导图也是预计更新的内容和当前进度(不定时更新)。 Linux磁盘涉及到的命令不是很多&#xff0c;但是在实际运维中的作用却很大&#xff0c;因为Linux系统及业务都会承载到硬盘上…

2024年新一代WebOffice内嵌网页组件——猿大师办公助手

背景 WebOffice控件这个中间件软件产品已存在二十余年&#xff0c;在国内众多大中小型企业、各级政府机关、科研机构和学校等事业单位的OA、ERP、文档系统、云盘等信息化B/S系统中得到了大量使用&#xff0c;为我国的信息化事业也做出了不小贡献。随着操作系统、浏览器及Offic…

随笔一、泰山派RK3566开发板调试串口波特率修改

摘要&#xff1a;立创泰山派RK3566开发板默认调试串口波特率是1500000bps&#xff0c;一般串口助手工具没有此波特率&#xff0c;为适应各种调试环境需要&#xff0c;打算修改调试串口波特率为115200bps 需要修改三个部分 1. uboot引导部分 修改tspi_linux_sdk/u-boot/config…

面试项目 | 带你玩转大学生智能汽车项目

文章目录 前言智能车系统介绍1.从智能车说起2.整体系统结构3.经验之谈 系统分层设计1.分层与模块化2.整个系统的总体设计控制与图像层嵌入式平台层 机械与硬件设计部分1.硬件布线2.电机H桥3.机械这块简单说几句吧 嵌入式平台软件搭建1.从任务调度说起大循环调度定时任务调度实时…

[吃瓜教程]南瓜书第6章软间隔与支持向量回归

1.软间隔支持向量机的模型 之前讨论的支持向量机的一个重要的假设前提是它的数据集是线性可分的。然而在现实任务中&#xff0c;线性不可分的情形才是最常见的&#xff0c;因此需要允许支持向量机犯错。这就是接下来要说的软间隔的支持向量机。 2.软间隔支持向量机的策略 从…