Vue3.0 声明式导航,编程式导航,路由,路由拦截案例

项目结构

App.vue:根组件

<template>
  <div>
    <router-view></router-view>
    <Tabbar></Tabbar>
  </div>
</template>
<script setup>
import Tabbar from '../src/views/Tabbar.vue'; //底部选项卡
import Home from '../src/views/Home.vue';
import Films from '../src/views/Films.vue';
import Cinemas from '../src/views/Cinemas.vue';
import NotFound from '../src/views/NotFound.vue';
import Login from '../src/views/Login.vue';
</script>
<style>
* {
  margin: 0;
  padding: 0;
}

ul {
  list-style: none;

}
</style>

index.js 路由器

import { createRouter, createWebHistory } from "vue-router"; //导入vue-router路由模块,createWebHashHistor函数

const routes = [
    {
        path: "/",  //路径: 
        redirect: "/Films"  //涉及到多级页面跳转需要用路径的跳转,不能用name的跳转; 浏览器进入http://localhost:5173/ 首先要跳转的路径是/Films,即:要跳转到http://localhost:5173/Films,而进入http://localhost:5173/Films后又发现/Films要重定向到/Films/NowPlaying,这样就实现了打开http://localhost:5173/就加载出来了http://localhost:5173/Films/NowPlaying内容
        // redirect: {
        //     name: "Films" //重定向到路由名称为Tabbar的路由中,这样当浏览器输入的是:http://localhost:5173/ 则会重定向跳转到 http://localhost:5173/Films
        // }
    },
    {
        path: "/FilmsDetail/:myid/:myname",  //路径:电影内容详细  "/FilmsDetail/:myid"的意思是:当路由以/FilmsDetail/为开头那么它后面的就是myid参数:举列:http://localhost:5173/FilmsDetail/123  那么这个123就是myid参数; 如果存在两个参数呢?"/FilmsDetail/:myid/:myname"  举列:http://localhost:5173/FilmsDetail/123/lily 那么这个123就是myid参数,lily就是myname参数
        name: "FilmsDetail",  //路由名称,如果不指定name 默认的name为default

        //当路由被触发时,该组件才会被异步加载,举列:打开页面就不会加载所有的组件,而是根据当前页面需要的组件进行异步加载
        //这样可以减少初始加载时间,提升用户体验,同时也节省了不必要的资源消耗。
        component: () => import("../views/FilmsDetail.vue")
    },
    {
        path: "/Tabbar",  //路径:底部选项卡
        name: "Tabbar",  //路由名称,如果不指定name 默认的name为default

        //当路由被触发时,该组件才会被异步加载,举列:打开页面就不会加载所有的组件,而是根据当前页面需要的组件进行异步加载
        //这样可以减少初始加载时间,提升用户体验,同时也节省了不必要的资源消耗。
        component: () => import("../views/Tabbar.vue"),

    },
    {
        path: "/Films",  //路径:电影
        name: "Films",  //路由名称,如果不指定name 默认的name为default

        //当路由被触发时,该组件才会被异步加载,举列:打开页面就不会加载所有的组件,而是根据当前页面需要的组件进行异步加载
        //这样可以减少初始加载时间,提升用户体验,同时也节省了不必要的资源消耗。
        component: () => import("../views/Films.vue"),
        children: [       //通过children配置子级路由
            {
                path: 'NowPlaying', //可以写成:'/Films/NowPlaying' 但是不要写成 '/NowPlaying'(正在热映)
                name: "NowPlaying",
                component: () => import("../views/NowPlaying.vue")
            },
            {
                path: 'ComingSoon', //可以写成:'/Films/ComingSoon' 但是不要写成 '/ComingSoon'(即将上映)
                component: () => import("../views/ComingSoon.vue")
            },
            {
                //为什么在子路由中添加一个Films路由?:答:因为在进入Films组件后就需要立即加载NowPlaying组件的内容。:注意:这里需要加斜杆/Films  ;
                //从app.vue组件中进入Films组件的时候,跳转的地址是:http://localhost:5173/Films,这时候就找到了顶级路由/Films,到然进入子级路由children,发现了后/Films需要跳转到/Films/NowPlaying
                path: '/Films',
                redirect: "/Films/NowPlaying"
            },

        ]
    },
    {
        path: "/Cinemas",  //路径:影院
        name: "Cinemas",   //路由名称,如果不指定name 默认的name为default

        //当路由被触发时,该组件才会被异步加载,举列:打开页面就不会加载所有的组件,而是根据当前页面需要的组件进行异步加载
        //这样可以减少初始加载时间,提升用户体验,同时也节省了不必要的资源消耗。
        component: () => import("../views/Cinemas.vue")
    },
    {
        path: "/Home",  //路径:我的
        name: "Home",   //路由名称,如果不指定name 默认的name为default

        //当路由被触发时,该组件才会被异步加载,举列:打开页面就不会加载所有的组件,而是根据当前页面需要的组件进行异步加载
        //这样可以减少初始加载时间,提升用户体验,同时也节省了不必要的资源消耗。
        component: () => import("../views/Home.vue"),
        meta: //加一个自定义参数:里面的参数随便我们定
        {
            requireAuth: true,   // 对当前路由路径做一个标记,代表进入这个页面需要登陆才能进。用于在router.beforeEach里面做登陆验证的时候,判断这个requireAuth参数是否为true,为true则需要登陆才能进入
            aaa: "wowow"
        }
    },
    {
        path: "/Login",  //登陆
        name: "Login",   //路由名称,如果不指定name 默认的name为default
        component: () => import("../views/Login.vue"),
    },
    {
        path: "/:pathMatch(.*)",  //404错误
        name: "NotFound",  //路由名称,如果不指定name 默认的name为default
        component: () => import("../views/NotFound.vue")
    }

]

//创建路由对象
const router = createRouter({
    history: createWebHistory(),     //这种方式基于浏览器 history API 的路由模式,url的样式是:http://localhost:5173/list
    routes: routes,
})

//路由全局拦截:在进入页面之前就进行拦截。可以用于做用户登陆验证
//参数to:  表示即将进入的目标路由对象
//参数from:表示当前导航正要离开的路由
//参数next:调用该方法后才能进入下一个钩子。next() 直接进入下一个钩子,next(false) 中断当前的导航。next('/') 或者 next({ path: '/' }) 则会进入一个不同的地址。
router.beforeEach(async (to, from, next) => {
    const isAuthenticated = await localStorage.getItem('token');

    // console.log(to.fullPath); //全路径
    // console.log(to.path);     //路径
    // console.log(to.name);     //路由名称
    // console.log(to.params);   //路由参数:http://localhost:5173/FilmsDetail/123
    // console.log(to.query);    //路由参数:http://localhost:5173/FilmsDetail?myid=123
    // console.log(to.meta);     //路由自定义参数


    //meta.requireAuth表示当前请求的页面需要验证, 并且未登录
    if (to.meta.requireAuth && !isAuthenticated) {
        next(`/login?redirect=${to.path}`) //to.fullPath
    }
    else next() //如果不是请求的登陆界面,或者已经登陆过了,则直接跳转到用户请求的界面
})

//路由全局拦截:在进入页面之后才进行触发拦截。
router.afterEach(async (to, form) => {
    //用的比较少,一般用于收集一些日志信息,做用户行为分析:例如:收集页面浏览量:PV
})

export default router //导出router路由对象//导出router路由对象

main.js 挂载Vue实例,注册路由器

import { createApp } from 'vue'
import './style.css'
import App from './App.vue'

import router from "../src/router/index.js" //导入路由js 
 
var app=createApp(App)
 
app.use(router) //注册路由组件
 
app.mount("#app")

Tabbar.vue:底部选项卡

<template>
    <div class="tabbar">
        <ul>
            <!--custom:自定义RouterLink,RouterLink默认是用<a>标签进行包裹的,我们可以改成我们自己的标签进行包裹:比如我们就采用自己的<li>标签进行包裹-->
            <!--v-slot="{ isActive, navigate } 这是插槽传参的机制,子组件向父组件暴露了两个对象isActive, navigate,
                其中isActive表示是否选中,navigate是一个触发导航的函数,表示点击之后要跳转的组件,其实就是to="/Tabbar/Films" :你可以想象一下 一个<a>标签你点击是不是要跳转到href指定的url地址去呢? -->
            <RouterLink custom to="/Films" v-slot="{ isActive, navigate }">
                <li :class="isActive ? 'highlighter' : ''" @click="navigate">电影</li>
            </RouterLink>
            <RouterLink custom to="/Cinemas" v-slot="{ isActive, navigate }">
                <li :class="isActive ? 'highlighter' : ''" @click="navigate">影院</li>
            </RouterLink>
            <RouterLink custom to="/Home" v-slot="{ isActive, navigate }">
                <li :class="isActive ? 'highlighter' : ''" @click="navigate">我的</li>
            </RouterLink>
            

            <!-- active-class="highlighter"的意思表示:在原有的样式的基础上追加我们自定义的样式:我们自定义样式就是加了一个文字高亮 -->
            <!-- <li>                
                <RouterLink to="/Films" active-class="highlighter">电影</RouterLink>
            </li>
            <li>
                <RouterLink to="/Cinemas" active-class="highlighter">影院</RouterLink>
            </li>
            <li>
                <RouterLink to="/Home" active-class="highlighter">我的</RouterLink>
            </li> -->
        </ul>
    </div>
</template>
<script setup>
import { ref } from 'vue'
import Films from './Films.vue'

</script>
<style scoped>
.tabbar {
    /*固定定位:元素的位置相对于浏览器窗口是固定位置。即使窗口是滚动的它也不会移动*/
    position: fixed;
    /*显示在底部*/
    bottom: 0;
    width: 100%;
    height: 50px;
    line-height: 50px;
    text-align: center;
    /* z-index属性是用来设置元素的堆叠顺序或者叫做元素层级,z-index的值越大,元素的层级越高。当元素发生重叠时,层级高的元素会覆盖在层级低的元素的上面,使层级低的元素的重叠部分被遮盖住 */
    z-index: 1000; 
    background: white;
}

.tabbar ul {
    /* 弹性布局 */
    display: flex;
}

.tabbar ul li {
    flex: 1;
    list-style-type: none;
}

.highlighter {
    color: red;
    /* 高亮 */
}
</style>

Films.vue 电影

<template>
    <div>
        <div style="height: 100px;line-height: 100px;text-align: center; border: 1px solid gray">轮播组件</div>
        <!--申明式导航-->
        <ul class="nvabar">
            <RouterLink custom to="/Films/NowPlaying" v-slot="{ isActive, navigate }">
                <li @click="navigate">
                    <span :class="isActive ? 'highlighter' : ''">正在热映</span>
                </li>
            </RouterLink>
            <RouterLink custom to="/Films/ComingSoon" v-slot="{ isActive, navigate }">
                <li @click="navigate">
                    <span :class="isActive ? 'highlighter' : ''">即将上映</span>
                </li>
            </RouterLink>
        </ul>
        <RouterView></RouterView>
    </div>
</template>
<script setup>
import NowPlaying from './NowPlaying.vue'
import ComingSoon from './ComingSoon.vue'
</script>
<style scoped>
.nvabar {
    /*固定定位:元素的位置相对于浏览器窗口是固定位置。即使窗口是滚动的它也不会移动*/
    /* position: fixed; */
    /*显示在底部*/
    /* bottom: 0; */
    display: flex;
    /* width: 100%; */
    height: 50px;
    line-height: 50px;
    text-align: center;
}

.nvabar li {
    flex: 1;
}

.highlighter {
     /* 高亮 */
    color: red;
    border-bottom: 3px solid red;
    padding-bottom: 7px;
   
}
</style>

FilmsDetail.vue 电影详细信息

<template>
    <div class="box">
        <div>
            <button @click="backClick">返回</button>
            <div>电影编号:{{ myid }}</div>
            <div>电影名称:{{ myname }}</div>
        </div>
        
    </div>
    <div class="recommend">
            <div><b>猜你喜欢:</b></div>
            <div>
                <RouterLink to="/FilmsDetail/6576/河边的错误">河边的错误</RouterLink>
            </div>
            <div>
                <RouterLink to="/FilmsDetail/6608/无价之宝">无价之宝 </RouterLink>
            </div>
        </div>
</template>
<style scoped>
.box {
    width: 100%;
    height: 600px;
    display: flex;
    /*表示是一个弹性盒子:它的能力就是让里面的子元素默认横向排列(当然也可以调整)再加一个属性flex-direction: column; 就编程纵向排列了*/
    flex-direction: column;
}

.recommend {
    width: 100%;
    height: 100px;
    display: flex;
    border: 2px solid red;
    justify-content: flex-start; /*space-between*/
    flex-wrap: wrap; /*横向宽度不够,自动排到第二行*/
}
.recommend div{
    margin: 5px;
    border: 1px solid gray;
 
}
</style>
<script setup>
import axios from 'axios';
import { ref, onMounted } from 'vue'
import { useRoute, useRouter, onBeforeRouteUpdate, onBeforeRouteLeave } from 'vue-router'

const route = useRoute();
const router = useRouter();
const myid = ref(0)
const myname = ref("");

myid.value = route.params.myid      //VCA写法获取myid参数
myname.value = route.params.myname  //VCA写法获取myname参数

// VOA (Options API):获取参数的写法

//如果传递参数的url形式是:http://localhost:5173/filmsdetail/123/lily::获取myid,和myname参数则是:this.$route.params.myid,this.$route.params.myname  种情况我们的路由配置是:
// {
// path: "/FilmsDetail/:myid/:myname"
// name: "FilmsDetail", 
// component: () => import("../views/FilmsDetail.vue")
// },

//如果传递参数的url形式是:http://localhost:5173/filmsdetail?myid=123&myname=lily: 那么这里要获取myid,myname的参数则是 this.$route.query.myid ,this.$route.query.myname  这种情况我们的路由配置是:
// {
// path: "/FilmsDetail"
// name: "FilmsDetail", 
// component: () => import("../views/FilmsDetail.vue")
// },
onMounted(async () => {

    //这里可以发起请求当前电影:然后将请求到的内容填充到DOM中
    //const currentFilm =await axios.get("https://m.maizuo.com/gateway?filmId=6616&k=2465358")
});
const backClick = () => {
    router.back(); //返回上一个页面

    // VOA (Options API):返回的写法:
    // this.$router.back()
}


//onBeforeRouteUpdate:当一个组件复用时,传递的参数发生变化就会触发这个钩子函数

//组件需要更新场景举列:我Films电影页面有一个电影列表,比如有如下电影:流浪地球,红海行动,湄公河,战狼,当我点击流浪地球,就会进入流浪地球的详情页面。http://localhost:5173/FilmsDetail/6616/流浪地球(注意:/6616/流浪地球 是参数,6616是电影ID,流浪地球是电影名称)
//而在“流浪地球”的详情页面中的底部有一个电影推荐,或者叫“猜你喜欢”的模块,里面向我们推荐了“红海行动” 
//当用户在“流浪地球”的详情页面中 点击“红海行动” 页面机会跳转到 “红海行动”的详情页面中 ,“红海行动”这部电影的url地址是:http://localhost:5173/FilmsDetail/6617/红海行动 (注意:/6617/红海行动 是参数,6617是电影ID,红海行动是电影名称)
//也就是说“流浪地球”与“红海行动”两部电影的URL地址是一样的,只是参数不同,这就是页面更新。

//电影:http://localhost:5173/FilmsDetail/6616/流浪地球 和 http://localhost:5173/FilmsDetail/6617/红海行动  这两个电影的url是一样的,都是http://localhost:5173/FilmsDetail 不同的只是参数不同,一个是/6616/流浪地球,另外一个是/6617/红海行动
//因为只是参数更新,就不会存在卸载组件,所以onMounted只会执行一次,当参数发生更新不会再次执行onMounted钩子函数
//假设我们在onMounted钩子函数中可能做了ajax去后台请求这部电影的数据,然后将数据展示在这个界面上,如果onMounted钩子函数没有被执行,那么当前界面中的展示的内容也不会被刷新))
onBeforeRouteUpdate((to, from) => {
    myid.value = to.params.myid
    myname.value = to.params.myname;

    //这里可以发起ajax请求,根据myid,或者myname等信息后后台获取电影数据然后填充到DOM中,实现页面重新渲染新的内容
    //const currentFilm =await axios.get("https://m.maizuo.com/gateway?filmId=6616&k=2465358")
})
</script>

NowPlaying.vue: 正在热映

<template>
    <div>
        <ul>
            <template v-for="item in filmsList" :key="item.filmId">
                <!--申明式导航:所谓申明式导航就是在标签上写上to:表示要跳转到哪里-->
                <RouterLink custom :to="'/FilmsDetail/' + item.filmId + '/' + item.name" v-slot="{ isActive, navigate }">
                    <li :class="isActive ? 'highlighter' : ''" @click="navigate">{{ item.name }}</li>
                </RouterLink>

                <!--编程式导航:所谓编程式导航其实就是通过调用@click方法,通过函数来执行router.push(...)跳转-->
                <!-- <li @click="handelClick(item.filmId,item.name)">{{ item.name }}</li> -->
            </template>
        </ul>
    </div>
</template>
<script setup>
import axios from 'axios';
import { ref, onBeforeMount, onMounted, onBeforeUnmount, onUnmounted } from "vue";
import { useRoute, useRouter } from 'vue-router'

const route = useRoute(); //它是用来拿路由请求参数的
const router = useRouter();

const filmsList = ref([]);
onMounted(async () => {
    const result = await axios({
        url: "https://m.maizuo.com/gateway?cityId=110100&pageNum=1&pageSize=10&type=1&k=7069698",
        headers: {
            'X-Client-Info': '{"a":"3000","ch":"1002","v":"5.2.1","e":"16992764191480200349024257"}',
            'X-Host': 'mall.film-ticket.film.list'
        }
    })
    filmsList.value = result.data.data.films //将请求到的电影列表赋值给filmsList
})


//用于编程式导航点击跳转
const handelClick = (filmId, name) => {
    // 第一种写法:字符串路径
    router.push(`/FilmsDetail/${filmId}/${name}`); //router.push("/FilmsDetail/"+filmId+"/"+name) :将一个新的请求路径添加到我们的 history 栈中进行跳转

    // 第二种写法:带有路径的对象
    // router.push({ path: `/FilmsDetail/${filmId}/${name}` })

    // 第三种写法:命名的路由,并加上参数,让路由建立url
    // router.push({ name: "FilmsDetail", params: { myid: filmId, myname: name } })

    // 第四种写法:带查询参数 例如:
    // router.push({ path: '/FilmsDetail', query: { myid: filmId, myname: name } });


    //VOA (Options API):中编程式导航的写法(以上四种写法都是一样的,只是this.$router与router.push不同)
    //this.$router.push("/FilmsDetail") //将一个新的请求路径添加到我们的 history 栈中进行跳转
}

</script>
<style scoped>
li {
    padding: 10px;
}
</style>

ComingSoon.vue:即将上映

<template>
    <div>即将上映</div>
</template>

Home.vue:我的

<template>
    <div>我的</div>
</template>

Login.vue:用户登陆

<template>
    <div>
        <button @click="login">登陆</button>
    </div>
</template>
<script setup>
import { useRoute, useRouter } from 'vue-router'
const route = useRoute();

console.log(route.query.redirect);//从需要登陆的界面跳转过来的

const router = useRouter();
const login = () => {
    localStorage.setItem("token", "111111111111111"); //模拟登陆,将token保存到localStorage中
    router.push(route.query.redirect);//登录完毕后跳转到你原先要进入的界面
    //route.push("/"); //登陆完毕跳转到首页
    //route.push({name:"Home"})// 登陆完毕跳转到路由名称为Home的页面
}
</script>

NotFound.vue:404错误页

<template>
    <div>
        404找不到啦~
    </div>
</template>

Cinemas.vue:影院

<template>
    <div>影院</div>
</template>

效果图

进入:http://localhost:5173/ 就会自动跳转到http://localhost:5173/Films/NowPlaying页面,首页

FilmsDetail.vue电影内容

我的

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

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

相关文章

预约按摩app小程序开发搭建;

预约按摩app小程序开发搭建&#xff1b; 后端&#xff1a;系统后端使用PHP语言开发 前端&#xff1a;前端使用uniapp进行前后端分离开发&#xff0c;支持&#xff08;公中号、小程序、APP&#xff09;。 用户端功能模块&#xff1a;技师选择、预约服务、优惠券、订单、技师服…

【快速使用ShardingJDBC的哈希分片策略进行分表】

文章目录 &#x1f50a;博主介绍&#x1f964;本文内容&#x1f34a;1.引入maven依赖&#x1f34a;2.启动类上添加注解MapperScan&#x1f34a;3.添加application.properties配置&#x1f34a;4.普通的自定义实体类&#x1f34a;5.写个测试类验证一下&#x1f34a;6.控制台打印…

【原创】java+jsp+servlet简单图书管理系统设计与实现

摘要&#xff1a; 图书管理系统是一个专门针对图书馆管理而设计的系统&#xff0c;它可以帮助图书管理员有效的对图书进行管理&#xff0c;在图书管理系统的设计中&#xff0c;首先要考虑的是系统的需求分析&#xff0c;该系统的设计与实现涉及多个方面&#xff0c;包括数据库…

RSA 2048位算法的主要参数N,E,P,Q,DP,DQ,Qinv,D分别是什么意思 哪个是通常所说的公钥与私钥 -安全行业基础篇5

非对称加密算法RSA 在RSA 2048位算法中&#xff0c;常见的参数N、E、P、Q、DP、DQ、Qinv和D代表以下含义&#xff1a; N&#xff08;Modulus&#xff09;&#xff1a;模数&#xff0c;是两个大素数P和Q的乘积。N的长度决定了RSA算法的安全性。 E&#xff08;Public Exponent&a…

09-MySQL主从复制

01-主从复制原理 MySQL主从复制是一种用于实现数据备份、读写分离和扩展性的技术。它基于二进制日志&#xff08;Binary Log&#xff09;来将主数据库上的更改操作同步到一个或多个从数据库。 MySQL主从复制的基本原理如下&#xff1a; 主服务器&#xff08;Master&#xff0…

数据结构-栈和队列力扣题

目录 有效的括号 用队列实现栈 用栈实现队列 设计循环队列 有效的括号 题目链接&#xff1a;力扣&#xff08;LeetCode&#xff09; 思路&#xff1a; 这道题可以用栈来解决&#xff0c;先让字符串中的左括号 ( &#xff0c; [ &#xff0c; { 入栈&#xff0c;s指向字符串下…

U-Mail信创邮件系统解决方案

近年来&#xff0c;在国家政策的大力引导和自身数字化转型需求驱动下&#xff0c;国产化成为国内数字化发展道路上的关键词&#xff0c;企业不断加强自主创新能力&#xff0c;进行信创建设&#xff0c;实现软硬件系统国产化替代&#xff0c;已成为大势所趋。邮件系统作为企业管…

代码随想录训练营Day1:二分查找与移除元素

本专栏内容为&#xff1a;代码随想录训练营学习专栏&#xff0c;用于记录训练营的学习经验分享与总结。 文档讲解&#xff1a;代码随想录 视频讲解&#xff1a;二分查找与移除元素 &#x1f493;博主csdn个人主页&#xff1a;小小unicorn ⏩专栏分类&#xff1a;C &#x1f69a…

某卢小说网站登录密码逆向

js逆向&#xff0c;今晚找了一个小说网站&#xff0c;分析一下登录密码的解密逆向过程&#xff0c;过程不是很难&#xff0c;分享下 学习网站aHR0cHM6Ly91LmZhbG9vLmNvbS9yZWdpc3QvbG9naW4uYXNweA 这个就是加密后的密码&#xff0c;今晚就逆向它&#xff0c;其他参数暂时不研究…

python+pytorch人脸表情识别

概述 基于深度学习的人脸表情识别&#xff0c;数据集采用公开数据集fer2013&#xff0c;可直接运行&#xff0c;效果良好&#xff0c;可根据需求修改训练代码&#xff0c;自己训练模型。 详细 一、概述 本项目以PyTorch为框架&#xff0c;搭建卷积神经网络模型&#xff0c;训…

【中间件篇-Redis缓存数据库02】Redis高级特性和应用(慢查询、Pipeline、事务、Lua)

Redis高级特性和应用(慢查询、Pipeline、事务、Lua) Redis的慢查询 许多存储系统&#xff08;例如 MySQL)提供慢查询日志帮助开发和运维人员定位系统存在的慢操作。所谓慢查询日志就是系统在命令执行前后计算每条命令的执行时间&#xff0c;当超过预设阀值,就将这条命令的相关…

腾讯云双11优惠活动有哪些?详细攻略来了!

2023年腾讯云双11大促活动正在火热进行中&#xff0c;百款热门云产品11.11云上盛惠&#xff0c;领折上折代金券最高再省9999元&#xff0c;助力开发者轻松上云&#xff01; 一、腾讯云双11活动入口 活动地址&#xff1a;点此直达 二、腾讯云双11活动时间 即日起至2023-11-30…

基于SSM的电动车上牌管理系统设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;采用JSP技术开发 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#x…

2012年计网408

第33题 在 TCP/IP 体系结构中, 直接为 ICMP 提供服务的协议是()A. PPPB. IPC. UDPD. TCP 本题考察TCP/IP体系结构中直接为ICMP协议提供服务的协议。如图所示。这是TCP/IP的四层体系结构。网际层的IP协议是整个体系结构中的核心协议&#xff0c;用于网络互联。网际控制报文协议…

MongoDB副本集特点验证

MongoDB副本集特点验证 mogodb副本集概述副本集搭建副本集结构验证结果源码地址 mogodb副本集概述 MongoDB副本集是将数据同步在多个服务器的过程。 复制提供了数据的冗余备份&#xff0c;并在多个服务器上存储数据副本&#xff0c;提高了数据的可用性&#xff0c; 并可以保证…

To create the 45th Olympic logo by using CSS

You are required to create the 45th Olympic logo by using CSS. The logo is composed of five rings and three rectangles with rounded corners. The HTML code has been given. It is not allowed to add, edit, or delete any HTML elements. 私信完整源码 <!DOCT…

MFC-TCP网络编程服务端-Socket

目录 1、通过Socket建立服务端&#xff1a; 2、UI设计&#xff1a; 3、代码的实现&#xff1a; &#xff08;1&#xff09;、CListenSocket类 &#xff08;2&#xff09;、CConnectSocket类 &#xff08;3&#xff09;、CTcpServerDlg类 1、通过Socket建立服务端&#xff…

分享一本让你真正理解深度学习的书

关注微信公众号&#xff1a;人工智能大讲堂&#xff0c;后台回复udl获取pdf文档。 今天要分享的书是Understanding Deep Learning&#xff0c;作者是西蒙普林斯&#xff0c;英国巴斯大学的荣誉教授&#xff0c;其个人学术能力相当强大&#xff0c;在AI领域有着深厚的学术造诣。…

网络唤醒(Wake-on-LAN, WOL)

远程唤醒最简单的方法&#xff1a;DDNSTOOpenwrt网络唤醒&#xff0c;完美实现。 原帖-远程唤醒_超详细windows设置远程唤醒wol远程连接&#xff08;远程开机&#xff09; WOL Web# 访问 Wake on Lan Over The Interweb by Depicus 可以无需借助软件很方便的从网页前端唤醒远…

MATLAB / Simulink HDL 快速入门

MATLAB / Simulink HDL 快速入门 我们将使用实例讲解MATLAB / Simulink HDL 使用入门。 开始这个项目&#xff0c;首先需要创建一个包含 Stateflow 的新 Simulink 。只需单击画布中的任意位置并开始输入 Stateflow。 此时应该能在画布上看到 Stateflow 图标。双击图标进行编辑。…