45 大事件项目 Day01
目标
- 利用
Git
管理大事件项目代码 - 安装并且使用
Live Server
插件 - 学会查阅
layui
文档 - 绘制出登录注册页面结构
- 添加表单元素自定义验证规则
- 查阅接口文档完成登录注册功能
- 知道
iframe
标签的使用 - 搭建后台主页界面
资源地址
- 线上
DEMO
项目地址:http://www.escook.cn:8086/ - 项目的
API
接口地址: https://www.showdoc.cc/escook?page_id=3707158761215217
0. 今天完成的功能效果
- 登录功能实现
- 注册功能实现
- 后台主页结构搭建
1. 项目前期的准备工作
1.1 项目结构搭建
- 将
素材
目录下的assets
和home
文件夹,拷贝到code
目录下assets > css
文件夹 自己编写的css
代码assets > fonts
字体图标文件夹assets > images
存放图标文件夹assets > js
自己js
代码的文件夹assets > lib
第三方依赖的文件夹home > dashboard.html
后台首页的页面效果
- 在
code
目录下新建login.html
和index.html
页面
1.2 使用GitHub
管理大事件的项目(⭐⭐⭐)
- 在
code
目录中运行git init
命令,初始化仓库 - 在
code
目录中运行git add .
命令,追踪要托管的文件 - 在
code
目录下运行git commit -m "init project"
命令,提交到本地仓库 - 新建
Github
仓库web_bigevent
- 登录
github
官网 - 点击左上角的 new 创建仓库,填写
Repository nam
e,描述说明,点击Private
选项,然后点击create repository
- 登录
- 将本地仓库和
Github
仓库建立关联关系 - 将本地仓库的代码推送到
Github
仓库中 - 运行
git checkout -b login
命令,创建并切换到login
分支
2. LayUI
这里我们使用到的是 layui
,先登录找到layui
的官方文档
使用的流程(⭐⭐⭐)
- 左侧是快捷导航,能够让我们快速找到对应的一些页面效果分类或者是功能分类
- 左侧选中我们想要的分类之后,右侧会有一个子分类,例如:左侧点击的布局,那么右侧是二级分类,里面有哪些布局的结构样式
- 当选中了对应的二级分类,就会跳转到对应效果那里
- 上面是示例效果
- 下面就是示例代码
- 我们需要做的就是找到对应效果的代码,
copy
到我们项目中,然后按照我们需要的效果进行调整即可
3. 登录注册功能
3.1 登录注册UI
效果实现(⭐⭐⭐)
3.1.1 登录注册页面搭建
- 引入
layui
的css
文件layui.css
,先引入第三方的,再引入自己的css
- 分为上下结构,上面头部的
Logo
区域 - 下面是 登录注册区域
- 修改一下对应样式,给body添加背景,给登录注册区域设置宽高,剧中显示,给里面title设置背景图片
[工作技巧] -我们在改第三方库的样式的时候 ,不要改别人的,应该是自己再写一个类名,liyo-ngcss的交集选择器 添加新增的类
结构示例代码
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>大事件-登录/注册</title><!-- 导入 LayUI 的样式 --><link rel="stylesheet" href="/assets/lib/layui/css/layui.css" /><!-- 导入自己的样式表 --><link rel="stylesheet" href="/assets/css/login.css" /></head><body><!-- 头部的 Logo 区域 --><div class="layui-main"><img src="/assets/images/logo.png" alt="" /></div><!-- 登录注册区域 --><div class="loginAndRegBox"><div class="title-box"></div></div></body>
</html>
css
示例代码
html,
body {margin: 0;padding: 0;height: 100%;width: 100%;background: url('/assets/images/login_bg.jpg') no-repeat center;background-size: cover;
}.loginAndRegBox {width: 400px;height: 310px;background-color: #fff;position: absolute;left: 50%;top: 50%;transform: translate(-50%, -50%);
}.title-box {height: 60px;background: url('/assets/images/login_title.png') no-repeat center;
}
3.1.2 登录和注册的按需切换
- 在登录注册区域里面(
loginAndRegBox
)定义两个div - 显然注册的div进行隐藏
- 给两个div绑定点击事件,点击了对应按钮,让对应的div进行显示,另外一个进行隐藏
结构示例代码
<!-- 登录注册区域 -->
<div class="loginAndRegBox"><div class="title-box"></div><!-- 登录的div --><div class="login-box"></div><!-- 注册的div --><div class="reg-box"></div>
</div>
css
示例代码
.reg-box {display: none;
}
js
示例代码
$(function() {// 点击“去注册账号”的链接$('#link_reg').on('click', function() {$('.login-box').hide()$('.reg-box').show()})// 点击“去登录”的链接$('#link_login').on('click', function() {$('.login-box').show()$('.reg-box').hide()})
})
3.1.3 绘制登录表单的结构样式
- 找到
layui
文档的页面元素 -> 表单
这一分类
- 拷贝 里面内容,不需要全部拷贝过来,我们拷贝第一行的输入框即可,注意:外面
form
表单域需要带上 - 删除里面的
label
提示内容,然后把lable
的父元素div
进行删除,不然前面label
删除了还有空隙在左侧 - 拷贝过来对应的
button
按钮,然后设置样式,让宽度填充整个父元素
结构示例代码
<!-- 登录的div --><div class="login-box"><!-- 登录的表单 --><form class="layui-form" action=""><!-- 用户名 --><div class="layui-form-item"><i class="layui-icon layui-icon-username"></i><input type="text" name="username" required lay-verify="required" placeholder="请输入用户名" autocomplete="off" class="layui-input" /></div><!-- 密码 --><div class="layui-form-item"><i class="layui-icon layui-icon-password"></i><input type="password" name="password" required lay-verify="required" placeholder="请输入密码" autocomplete="off" class="layui-input" /></div><!-- 登录按钮 --><div class="layui-form-item"><!-- 注意:表单提交按钮和普通按钮的区别,就是 lay-submit 属性 --><button class="layui-btn layui-btn-fluid layui-btn-normal" lay-submit>登录</button></div><div class="layui-form-item links"><a href="javascript:;" id="link_reg">去注册账号</a></div></form></div>
css
示例代码
- 给 表单域设置内边距,左右留一点缝隙
- 给下面的 links 设置 flex 布局,让里面 a标签 居右边显示
- 修改 a 标签文字大小
.layui-form {padding: 0 30px;
}.links {display: flex;justify-content: flex-end;
}.links a {font-size: 12px;
}
3.1.4 绘制文本框前面的小图标
- 在
layui
中给我们提供了一些图标,我们直接使用即可
- 在用户名的文本框之前,添加如下的标签结构
<i class="layui-icon layui-icon-username"></i>
- 在密码框之前,添加如下的标签结构
<i class="layui-icon layui-icon-password"></i>
- 修改一下对应样式
.layui-form-item {position: relative;
}.layui-icon {position: absolute;left: 10px;top: 10px;
}.layui-input {padding-left: 32px;
}
3.1.5 绘制注册表单的结构样式
- 注册表单与登录是差不多的,多了一个 输入框,我们把之前登录的结构直接拷贝过来
- 修改一下里面对应内容
结构示例代码
<!-- 注册的div --><div class="reg-box"><!-- 注册的表单 --><form class="layui-form" action=""><!-- 用户名 --><div class="layui-form-item"><i class="layui-icon layui-icon-username"></i><input type="text" name="username" required lay-verify="required" placeholder="请输入用户名" autocomplete="off" class="layui-input" /></div><!-- 密码 --><div class="layui-form-item"><i class="layui-icon layui-icon-password"></i><input type="password" name="password" required lay-verify="required" placeholder="请输入密码" autocomplete="off" class="layui-input" /></div><!-- 密码确认框 --><div class="layui-form-item"><i class="layui-icon layui-icon-password"></i><input type="password" name="repassword" required lay-verify="required" placeholder="再次确认密码" autocomplete="off" class="layui-input" /></div><!-- 注册按钮 --><div class="layui-form-item"><!-- 注意:表单提交按钮和普通按钮的区别,就是 lay-submit 属性 --><button class="layui-btn layui-btn-fluid layui-btn-normal" lay-submit>注册</button></div><div class="layui-form-item links"><a href="javascript:;" id="link_login">去登录</a></div></form></div>
3.2 登录注册逻辑实现(⭐⭐⭐)
3.2.1 实现登录表单的验证
- 在
layui
中,默认有帮我们验证表单元素的逻辑 - 导入
layui
的js
文件
<script src="/assets/lib/layui/layui.all.js"></script>
- 为需要验证的表单项添加
lay-verify
属性,同时指定具体的校验规则即可
<input type="text" name="username" required lay-verify="required" placeholder="请输入用户名" autocomplete="off" class="layui-input" />
3.2.2 自定义校验规则
- 通过查阅文档,我们只要如果需要去自定义校验规则,我们先要得到form模块对象
var form = layui.form
- 通过
form.verify()
函数自定义校验规则,里面是key:value
形式,key后续对应设置到标签的lay-verity
属性中,value
就是验证的规则,这里定义了两个自定义校验规则,一个是密码框,利用的是正则,一个是确认密码
form.verify({// 自定义了一个叫做 pwd 校验规则pwd: [/^[\S]{6,12}$/, '密码必须6到12位,且不能出现空格'],// 校验两次密码是否一致的规则repwd: function(value) {// 通过形参拿到的是确认密码框中的内容// 还需要拿到密码框中的内容// 然后进行一次等于的判断// 如果判断失败,则return一个提示消息即可var pwd = $('.reg-box [name=password]').val()if (pwd !== value) {return '两次密码不一致!'}}})
- 按需为表单项添加校验规则,如果有多个规则,用 | 隔开就好
<input type="password" name="repassword" required lay-verify="required|pwd|repwd" placeholder="再次确认密码" autocomplete="off" class="layui-input" />
3.2.3 发起注册用户的Ajax请求
-
查阅接口文档,关注以下几个重点信息
- 请求URL
- 请求方式
- 参数名
- 响应数据
-
给按钮添加id,添加绑定事件,在事件处理函数里面先取消表单提交的默认行为
-
利用
$.ajax()
进行网络请求,注意添加根路径http://ajax.frontend.itheima.net
-
请求成功之后提示用户
-
利用
layer.msg
来进行提示 -
获取到
layer
内置模块var layer = layui.layer
-
模拟用户点击了去登陆
-
js
示例代码
// 监听注册表单的提交事件
$('#form_reg').on('submit', function(e) {// 1. 阻止默认的提交行为e.preventDefault()// 2. 发起Ajax的POST请求var data = {username: $('#form_reg [name=username]').val(),password: $('#form_reg [name=password]').val()}$.post('http://ajax.frontend.itheima.net/api/reguser', data, function(res) {if (res.status !== 0) {return layer.msg(res.message)}layer.msg('注册成功,请登录!')// 模拟人的点击行为$('#link_login').click()})
})
3.2.4 发起登录的Ajax请求
- 查阅接口文档,关注几个重点要(请求URL,请求方式,请求参数,响应数据)
- 给按钮添加id,添加绑定事件,在事件处理函数里面先取消表单提交的默认行为
- 利用
$.ajax()
进行网络请求,注意添加根路径 - 请求成功之后提示用户,保持token信息,跳转到后台主页
- token 用来标识用户是否登录的令牌,后台的页面需要用户登录之后才能查阅,那么权限校验的机制也就出来了,需要检验权限的页面后台先判断请求头里面是否有token,以此来判断是否是登录状态
js
示例代码
// 监听登录表单的提交事件
$('#form_login').submit(function(e) {// 阻止默认提交行为e.preventDefault()$.ajax({url: 'http://ajax.frontend.itheima.net/api/login',method: 'POST',// 快速获取表单中的数据data: $(this).serialize(),success: function(res) {if (res.status !== 0) {return layer.msg('登录失败!')}layer.msg('登录成功!')// 将登录成功得到的 token 字符串,保存到 localStorage 中localStorage.setItem('token', res.token)// 跳转到后台主页location.href = '/index.html'}})
})
3.2.5 在ajaxPrefilter
中统一拼接请求的根路径
每次请求的时候都需要去添加根路径,比较的麻烦,如果根路径进行了修改,那么每个请求的页面都需要调整,那么jQuery
中提供了一个 过滤器,可以帮我们统一去进行设置,而这个过滤器调用的时机是在我们调用 $.ajax()
之后,请求真正发给后台之前调用的: $.ajax() > ajaxPrefilter过滤器 -> 发送请求给服务器
- 在
/assets/js
目录中新建baseAPI.js
- 调用
$.ajaxPrefilter()
函数,里面传递一个回调函数,回调函数里面有一个形成options
,这个形成里面就包含了这一次请求的相关信息
js
示例代码
// 注意:每次调用 $.get() 或 $.post() 或 $.ajax() 的时候,
// 会先调用 ajaxPrefilter 这个函数
// 在这个函数中,可以拿到我们给Ajax提供的配置对象
$.ajaxPrefilter(function(options) {// 在发起真正的 Ajax 请求之前,统一拼接请求的根路径options.url = 'http://ajax.frontend.itheima.net' + options.url
})
3.2.6 提交login
分支的代码到GitHub
- 运行
git add .
命令 - 运行
git commit -m "完成了登录和注册的功能"
命令 - 运行
git push -u origin login
命令 - 运行
git checkout master
命令 - 运行
git merge login
命令 - 运行
git push
命令 - 运行
git checkout -b index
命令
4. 后台主页
4.1 快速实现后台主页的布局效果
- 找到
LayUI
文档里面 页面元素 > 布局 > 后台布局
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-piF24xDb-1600483111545)(images/后台布局.png)]
- 拷贝里面的代码,修改以下对应的文字内容
结构示例代码
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>后台主页</title><!-- 导入 layui 的样式表 --><link rel="stylesheet" href="/assets/lib/layui/css/layui.css" /></head><body class="layui-layout-body"><div class="layui-layout layui-layout-admin"><div class="layui-header"><div class="layui-logo"><img src="/assets/images/logo.png" alt="" /></div><!-- 头部区域(可配合layui已有的水平导航) --><ul class="layui-nav layui-layout-right"><li class="layui-nav-item"><a href="javascript:;"><img src="http://t.cn/RCzsdCq" class="layui-nav-img" />个人中心</a><dl class="layui-nav-child"><dd><a href="">基本资料</a></dd><dd><a href="">更换头像</a></dd><dd><a href="">重置密码</a></dd></dl></li><li class="layui-nav-item"><a href="">退出</a></li></ul></div><div class="layui-side layui-bg-black"><div class="layui-side-scroll"><!-- 左侧导航区域(可配合layui已有的垂直导航) --><ul class="layui-nav layui-nav-tree" lay-filter="test"><li class="layui-nav-item layui-nav-itemed"><a class="" href="javascript:;">所有商品</a><dl class="layui-nav-child"><dd><a href="javascript:;">列表一</a></dd><dd><a href="javascript:;">列表二</a></dd><dd><a href="javascript:;">列表三</a></dd><dd><a href="">超链接</a></dd></dl></li><li class="layui-nav-item"><a href="javascript:;">解决方案</a><dl class="layui-nav-child"><dd><a href="javascript:;">列表一</a></dd><dd><a href="javascript:;">列表二</a></dd><dd><a href="">超链接</a></dd></dl></li><li class="layui-nav-item"><a href="">云市场</a></li><li class="layui-nav-item"><a href="">发布商品</a></li></ul></div></div><div class="layui-body"><!-- 内容主体区域 --><div style="padding: 15px;">内容主体区域</div></div><div class="layui-footer"><!-- 底部固定区域 -->© layui.com - 底部固定区域</div></div><!-- 导入 layui 的JS文件 --><script src="/assets/lib/layui/layui.all.js"></script></body>
</html>
4.2 修改侧边栏的结构(⭐⭐⭐)
- 找到没有二级分类的
li
,移植到第一个位置 - 对应修改里面的文字内容即可
结构示例代码
<div class="layui-side layui-bg-black"><div class="layui-side-scroll"><!-- 左侧导航区域(可配合layui已有的垂直导航) --><ul class="layui-nav layui-nav-tree"><li class="layui-nav-item"><a href="/">首页</a></li><li class="layui-nav-item"><a class="" href="javascript:;">文章管理</a><dl class="layui-nav-child"><dd><a href="javascript:;">文章类别</a></dd><dd><a href="javascript:;">文章列表</a></dd><dd><a href="javascript:;">发布文章</a></dd></dl></li><li class="layui-nav-item"><a href="javascript:;">个人中心</a><dl class="layui-nav-child"><dd><a href="javascript:;">基本资料</a></dd><dd><a href="javascript:;">更换头像</a></dd><dd><a href="javascript:;">重置密码</a></dd></dl></li></ul></div>
</div>
4.3 使用lay-shrink
实现左侧菜单互斥效果
目前效果是侧边栏的二级列表都可以展开,这个不是我们需要的效果,我们需要的是,一个二级列表展开之后,另外的二级列表需要关闭
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UKKNJ1yu-1600483111548)(images/侧边栏效果.png)]
- 只需要给侧边栏的
ul
添加一个lay-shrin
属性
示例代码
<div class="layui-side layui-bg-black"><div class="layui-side-scroll"><!-- 左侧导航区域(可配合layui已有的垂直导航) --><ul class="layui-nav layui-nav-tree" lay-shrink="all"><!-- 省略其他代码 --></ul></div>
</div>
4.4 为菜单项添加图标
利用第三方的字体图标库来实现
- 导入第三方的图标库
- 哪个地方需要使用,添加 span标签,里面设置
class
类名- 注意:
iconfont
这个类名不能省略
- 注意:
<!-- 导入第三方图标库 -->
<link rel="stylesheet" href="/assets/fonts/iconfont.css" />...<div class="layui-side layui-bg-black"><div class="layui-side-scroll"><!-- 左侧导航区域(可配合layui已有的垂直导航) --><ul class="layui-nav layui-nav-tree" lay-shrink="all"><li class="layui-nav-item"><a href=""><span class="iconfont icon-home"></span>首页</a></li><li class="layui-nav-item"><a class="" href="javascript:;"><span class="iconfont icon-16"></span>文章管理</a>...</li><li class="layui-nav-item"><a href="javascript:;"><span class="iconfont icon-user"></span>个人中心</a>...</li></ul></div></div>
- 修改头部“退出”按钮的结构
<li class="layui-nav-item"><a href=""><span class="iconfont icon-tuichu"></span>退出</a>
</li>
- 导入自己的样式表文件
<link rel="stylesheet" href="/assets/css/index.css" />
- 编写自己的样式
.layui-footer {text-align: center;font-size: 12px;
}.iconfont {margin-right: 8px;
}.layui-icon {margin-right: 8px;margin-left: 20px;
}
4.5 使用iframe
标签在内容主体区域显示网页内容(⭐⭐⭐)
如果每个导航栏对应的内容都写在一个页面中,会导致页面太臃肿,不利于维护,遵循模块化开发的思路,我们可以不同导航栏的内容是一个页面,这样我们就利用 iframe
来实现了
- 在页面主体的 div 中添加
iframe
<div class="layui-body"><!-- 内容主体区域 --><iframe name="fm" src="" frameborder="0"></iframe></div>
- 为
首页
链接添加href
和target
属性
<a href="/home/dashboard.html" target="fm"><span class="iconfont icon-home"></span>首页</a>
- 设置对应样式
iframe {width: 100%;height: 100%;
}.layui-body {overflow: hidden;
}
- 指定默认
iframe
页面,添加src
的属性即可
<iframe name="fm" src="/home/dashboard.html" frameborder="0"></iframe>
- 为
首页
对应的导航 Item 项添加默认高亮效果,layui-this
属性
<li class="layui-nav-item layui-this"><a href="/home/dashboard.html" target="fm"><span class="iconfont icon-home"></span>首页</a>
</li>
- 强制清除
<a>
链接的CSS3
动画
a {transition: none !important;
}
4.6 渲染图片头像和文字头像
- 找到对应的位置,添加如下结构
<!-- 右侧导航栏上面头像 -->
<a href="javascript:;" class="userinfo"><img src="http://t.cn/RCzsdCq" class="layui-nav-img" /><span class="text-avatar">A</span>个人中心
</a>
<!-- 左侧侧边栏上面头像 -->
<div class="userinfo"><img src="http://t.cn/RCzsdCq" class="layui-nav-img" /><span class="text-avatar">A</span><span id="welcome">欢迎 ***</span>
</div>
- 修改对应的样式
.userinfo {height: 60px;line-height: 60px;text-align: center;font-size: 12px;user-select: none;
}
.layui-side-scroll .userinfo {border-bottom: 1px solid #282b33;
}
.layui-nav-img {width: 40px;height: 40px;
}
.text-avatar {display: inline-block;width: 40px;height: 40px;background-color: #009688;border-radius: 50%;line-height: 40px;text-align: center;font-size: 20px;color: #fff;position: relative;top: 4px;margin-right: 10px;
}
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- 【小程序云开发挑战赛】长大寻物-明远队作品说明书
目录第一章 项目背景1.1 问题背景1.2 市场背景第二章 目的与意义2.2 项目实施的意义1.对个人2.对校园3.对社会第三章 项目创新与竞争优势3.1 创新特色详述3.2 市场现有产品所存在的问题3.3 本系统的具体优势第四章 概要设计4.1 概要设计与实现5.2 数据表详细设计第六章 部分代码…...
2024/4/10 20:06:32 - Java学者福音,阿里P9资深架构师竟写出Java岗面试必过的核心笔记
号外,号外:阿里巴巴P8架构师竟编写出了一本Java岗必备核心笔记,对于程序员来说真是一大福音,不管是初学者,还是资深架构师相信都能让你受益匪浅。此笔记不但内容覆盖面广, 条理清晰,而且图文并茂…...
2024/4/12 10:41:51 - promethes的安装以及搭配supervisor
七、Prometheus的应用 前文已经说过我们整体的监控系统采用 Prometheus Grafana 的方案。这也是当前企业中普遍采用的监控方案,这里我们以Nginx的请求和Flume Argent实时监控为例,来讲解监控方案的实施。 7.1 prometheus的简介 supervisor是python的…...
2024/4/28 19:18:07 - Netty学习笔记(二)Channel的分类
Channel分类 在Netty中存在众多Channel类和接口,大致关系如下: Netty中Channel类图 Channel:和Java Nio中的Channel同名,是Netty对网络底层读写和连接的抽象。AbstractChannel: 是Channel的抽象实现类,抽…...
2024/4/12 16:27:27 - HMM(隐马尔可夫)中文分词
一、隐马尔可夫模型 隐马尔可夫模型(Hidden Markov Model,HMM)是用来描述一个含有隐含未知参数的马尔可夫过程。 1、举例理解 假设我手里有三个不同的骰子。第一个骰子是我们平常见的骰子(称这个骰子为D6),…...
2024/4/26 3:13:07 - 【Python项目】外星人入侵项目笔记
【Python项目】外星人入侵~ 作者:Code_Linghu-令狐 1、Windows系统中安装Pygame 1.1检查python环境是否安装成功 打开 CMD命令行输入 python 执行成功的截图,说明python安装成功! 如果你没有安装python环境和开发工具则打开如下链接&…...
2024/4/30 10:27:27 - Aliyun Linux(Centos7) Rabbit health check failed
这几天开始在自己阿里云服务器,部署rabbit mq 。遇到一个问题,给大家一点思路 问题描述 rabbit mq 安装成功 控制台能够跟正常登录, 通过控制台创建用户 XXX ,并且赋予了权限 后来设置了 etc 下的 监听的端口,和远程用…...
2024/4/27 1:00:28 - 什么是次世代3D建模,次世代游戏模型怎么被做出来?
什么是次世代 次世代这个名字源自日语,指还未广泛应用的先进技术。 VR游戏的诞生,世代游戏有质的飞跃。VR玩家可以“亲身进入”游戏场景中,切身感受游戏里的氛围。不但能近距离观看场景、道具和角色,还可以近距离体验特效。 与…...
2024/4/13 19:06:48 - LeetCode 1191. K 次串联后最大子数组之和--动态规划求最大子区间和
给你一个整数数组 arr 和一个整数 k。 首先,我们要对该数组进行修改,即把原数组 arr 重复 k 次。 举个例子,如果 arr [1, 2] 且 k 3,那么修改后的数组就是 [1, 2, 1, 2, 1, 2]。 然后,请你返回修改后的数组中的最…...
2024/5/6 5:57:20 - ZooKeeper单机伪集群搭建
安装配置请看前文: Linux系统安装ZooKeeper 开始搭建 cp多个zoo.cfg文件,分别命令为zoo1.cfg、zoo2.cfg、zoo3.cfg zoo.cfg #f milliseconds of each tick tickTime2000 # The number of ticks that the initial # synchronization phase can take i…...
2024/4/7 11:37:37 - 链栈java实现
1.用java实现一个链栈 import java.util.Iterator; import java.util.NoSuchElementException;import edu.princeton.cs.algs4.StdIn; import edu.princeton.cs.algs4.StdOut;//链表栈 public class LinkedStack<Item> implements Iterable<Item> {private int n;…...
2024/5/5 7:24:46 - 04_装饰模式
模式定义: 动态(组合)地给一个对象增加一些额外的职责。就增加功能而言,装饰模式比生成子类(继承)更为灵活(消除重复代码 & 减少子类个数) 使用动机: 在某些情况下…...
2024/4/20 12:33:50 - 基于柯西矩阵的Erasure Code技术详解
原文 http://alanwu.blog.51cto.com/3652632/1410132 一、概述 Erasure Code 可以应用于分布式存储系统中,替代多份数据拷贝的数据冗余方式,从而可以提高存储空间利用率。此外, Erasure code 还可以应用于传统 RAID系统中,增加…...
2024/4/23 20:51:38 - IDEA打开自动导包
学Spring Boot网上教程进行编写测试类的时候,遇到了以下异常 org.junit.runners.model.InvalidTestClassError: Invalid test class com.hznu.zl.chapter11.Chapter11ApplicationTests:1. No runnable methodsat org.junit.runners.ParentRunner.validate(ParentRu…...
2024/4/30 9:54:13 - 云服务器SQL数据库端口1433访问不了?------三步设置教你快速开放云数据库端口
相信很多新手小伙伴会经常遇到云服务器端口访问不了而苦恼 明明安全组内已经加上了数据库端口,防火墙也关了,实际上呢又连接不上. 今天给大家实际演示一下如何正确开放云数据库端口. 第一步 进入云控制台(演示用的是免费试用版腾讯云,所有云服务器操作步骤类似) 找到安全组,没…...
2024/4/28 4:16:29 - 二分查找的循环退出条件
public int search(int[] nums, int target) {int low0, highnums.length-1;while (low<high) {int mid (lowhigh)/2;if (nums[mid] target) {return mid;} else if (nums[mid] > target) {high mid-1;} else { low mid1;}}return -1; }以上是一个常规的二分查找法代…...
2024/4/24 8:24:45 - Vuejs与Axios项目开发,简单的网页版的播放器实现
前提说明 在这里使用到vue和axios,vue进行数据绑定等,axios进行从连接获取数据。在这里axios获取的链接及api如下: https://autumnfish.cn/search?keywords 根据关键字进行搜索https://autumnfish.cn/song/url?id 搜索之后根据返回的id来…...
2024/4/24 22:53:33 - AI全自动生成视频神器
AI全自动生成视频神器:只需要输入一个关键词,即可自动生成一批原创视频出来。亦可根据易撰上的爆文,采集爆文和相关视频自动生成原创视频。软件会根据关键词采集阅读量高的文章,并自动采集相关视频,对这些视频进行一个…...
2024/4/7 11:37:29 - 即拼商城系统开发源码(Java)
前言 运用JAVA语言开发即拼商城系统,分享源码,以及开发总结;完整源码看下面 import java.util.regex.Matcher; import java.util.regex.Pattern;public class RegexMatches {public static void main(String args[]) {String str "&qu…...
2024/4/22 6:24:10 - 05_桥模式
使用动机: 由于某些类型的固有的实现逻辑,使得它们具有两个变化的维度,乃至多个维度的变化。 class MessagerImpl { public:~MessagerImpl() { }public:virtual void PlaySound() 0;virtual void WriteText(string &msg) 0;virtual vo…...
2024/4/18 14:40:31
最新文章
- js开启子线程及其使用
众所周知,js是单线程,但是可以开启子线程来帮忙处理一些数据,但是这个子线程是有限制的 1.必须是同源 2.完全受主线程控制 3.不能在子线程中操作dom节点 4.子线程没有window,可以使用self 5.等等 具体的查看官网 进程切换是要耗时…...
2024/5/6 9:51:35 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/5/6 9:38:23 - [实战经验]Mybatis的mapper.xml参数#{para}与#{para, jdbcType=BIGINT}有什么区别?
在MyBatis框架中,传入参数使用#{para}和#{para, jdbcTypeBIGINT}的有什么区别呢? #{para}:这种写法表示使用MyBatis自动推断参数类型,并根据参数的Java类型自动匹配数据库对应的类型。例如,如果参数para的Java类型是Lo…...
2024/5/4 11:09:35 - Verilog基础【二】
3.1 Verilog 连续赋值 关键词:assign, 全加器 连续赋值语句是 Verilog 数据流建模的基本语句,用于对 wire 型变量进行赋值。: assign LHS_target RHS_expression ;LHS(left hand side)…...
2024/5/5 17:51:17 - 416. 分割等和子集问题(动态规划)
题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义:dp[i][j]表示当背包容量为j,用前i个物品是否正好可以将背包填满ÿ…...
2024/5/5 18:19:03 - 【Java】ExcelWriter自适应宽度工具类(支持中文)
工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...
2024/5/5 12:22:20 - Spring cloud负载均衡@LoadBalanced LoadBalancerClient
LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon,直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件,我们讨论Spring负载均衡以Spring Cloud2020之后版本为主,学习Spring Cloud LoadBalance,暂不讨论Ribbon…...
2024/5/5 19:59:54 - TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案
一、背景需求分析 在工业产业园、化工园或生产制造园区中,周界防范意义重大,对园区的安全起到重要的作用。常规的安防方式是采用人员巡查,人力投入成本大而且效率低。周界一旦被破坏或入侵,会影响园区人员和资产安全,…...
2024/5/6 7:24:07 - VB.net WebBrowser网页元素抓取分析方法
在用WebBrowser编程实现网页操作自动化时,常要分析网页Html,例如网页在加载数据时,常会显示“系统处理中,请稍候..”,我们需要在数据加载完成后才能继续下一步操作,如何抓取这个信息的网页html元素变化&…...
2024/5/5 15:25:47 - 【Objective-C】Objective-C汇总
方法定义 参考:https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...
2024/5/6 6:01:13 - 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】
👨💻博客主页:花无缺 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】🌏题目描述🌏输入格…...
2024/5/6 7:24:06 - 【ES6.0】- 扩展运算符(...)
【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数࿰…...
2024/5/6 1:08:53 - 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?
文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕,各大品牌纷纷晒出优异的成绩单,摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称,在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁,多个平台数据都表现出极度异常…...
2024/5/5 18:50:00 - Go语言常用命令详解(二)
文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令,这些命令可以帮助您在Go开发中进行编译、测试、运行和…...
2024/5/6 0:27:44 - 用欧拉路径判断图同构推出reverse合法性:1116T4
http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b,我们在 a i a_i ai 和 a i 1 a_{i1} ai1 之间连边, b b b 同理,则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然࿰…...
2024/5/6 7:24:04 - 【NGINX--1】基础知识
1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息,并安装一些有助于配置官方 NGINX 软件包仓库的软件包: apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...
2024/5/6 7:24:04 - Hive默认分割符、存储格式与数据压缩
目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限(ROW FORMAT)配置标准HQL为: ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...
2024/5/5 13:14:22 - 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法
文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中,传感器和控制器产生大量周…...
2024/5/6 7:24:03 - --max-old-space-size=8192报错
vue项目运行时,如果经常运行慢,崩溃停止服务,报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中,通过JavaScript使用内存时只能使用部分内存(64位系统&…...
2024/5/5 17:03:52 - 基于深度学习的恶意软件检测
恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞,例如可以被劫持的合法软件(例如浏览器或 Web 应用程序插件)中的错误。 恶意软件渗透可能会造成灾难性的后果,包括数据被盗、勒索或网…...
2024/5/5 21:10:50 - JS原型对象prototype
让我简单的为大家介绍一下原型对象prototype吧! 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定,每一个构造函数都有一个 prototype 属性,指向另一个对象,所以我们也称为原型对象…...
2024/5/6 7:24:02 - C++中只能有一个实例的单例类
C中只能有一个实例的单例类 前面讨论的 President 类很不错,但存在一个缺陷:无法禁止通过实例化多个对象来创建多名总统: President One, Two, Three; 由于复制构造函数是私有的,其中每个对象都是不可复制的,但您的目…...
2024/5/6 7:24:01 - python django 小程序图书借阅源码
开发工具: PyCharm,mysql5.7,微信开发者工具 技术说明: python django html 小程序 功能介绍: 用户端: 登录注册(含授权登录) 首页显示搜索图书,轮播图࿰…...
2024/5/5 17:03:21 - 电子学会C/C++编程等级考试2022年03月(一级)真题解析
C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...
2024/5/5 15:25:31 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57