当前位置: 首页 > news >正文

网络安全知识问答微信小程序的设计与实现

网络安全知识问答微信小程序的设计与实现,说白了,就是搭建一款网络安全知识问答微信小程序,类似网络安全百科直通车。三步走。

需求沟通

进行需求沟通,此处省略1000字。

画草图

根据沟通的需求,进行整理,然后绘制草图。

搭建页面

引导页页面布局与样式

<image src="/image/b1.png" class="mw-bg"></image>
<view class="mw-btn"><view class="mw-answer"><view bindtap="login" wx:if="{{!hasUserInfo}}"><button class='cu-btn block round lg bg-blue'> 微信授权登录 </button></view><view bindtap="goToStart" wx:else><button class='cu-btn block round lg bg-blue'>开始答题</button></view><view><button class="cu-btn block round lg line-blue margin-top" open-type="share"> 推荐给好友 </button></view></view></view>

page{background-color: #eff5ff;
}
.mw-bg {position: absolute;top: 0;left: 0;width: 750rpx;height: 100vh;
}
.mw-answer {padding: 100rpx 150rpx 10rpx;
}
.mw-weixin.text-center {color: #333;padding: 30rpx 0 0;
}
.mw-btn {position: absolute;bottom: 20rpx;left: 0;width: 750rpx;z-index: 2;
}

登录页页面布局与样式

<view class="text-center padding-top-xl"><button class="avatar-wrapper" open-type="chooseAvatar" bind:chooseavatar="onChooseAvatar"><image class="avatar" src="{{avatarUrl}}" mode="widthFix"></image></button> 
</view><view class="weui-input-box solids-top solids-bottom padding margin-top"><input type="nickname" class="weui-input" placeholder="请输入昵称"  maxlength="12" bindinput="bindKeyInput" bindblur="bindblurFn" />
</view><view class="padding margin-top"><button class='cu-btn block round lg bg-blue' bindtap="login"> 登 录 </button>
</view>

/* pages/login/login.wxss */
page{background-color: #fff;
}
.avatar-wrapper {display: inline-block;width: 100rpx;height: 100rpx;padding: 0;margin: 0;
}

首页页面布局与样式


<view class="mw-page"><swiper class="screen-swiper" indicator-dots="true" circular="true"  autoplay="true" interval="5000" duration="500"><swiper-item wx:for="{{banner}}" wx:key="index"><image src="{{item}}" mode='aspectFill'></image></swiper-item></swiper><view class="padding"><view class="bg-blue padding radius text-center light"><view class="text-xl text-bold margin-bottom-xs">网络安全宣传</view><view class="text-lg">保护个人信息</view></view></view><view class="mw-content padding-bottom"><view class="cu-bar bg-white padding-top-sm"><view class='action'><text class='icon-titles text-blue'></text><text class='text-xl text-bold'>热点问题</text></view></view><view class='padding-left-sm padding-right-sm' wx:for="{{hotList}}" wx:key="index"><view class='padding-sm' bindtap="goToViewAnswer" data-id="{{item._id}}"><view class='bg-sky padding radius shadow-warp flex justify-between align-center'><view class="text-lg">热点{{index+1}}、{{item.question}}</view><text class="icon-right lg text-white"></text></view></view></view></view>
</view>

page{background-color: #fff;
}
.mw-bg {position: absolute;top: 0;left: 0;width: 750rpx;height: 100vh;
}
.mw-btn {position: absolute;bottom: 10rpx;left: 0;width: 750rpx;z-index: 2;
}
.mw-answer {padding: 100rpx 150rpx 30rpx;
}

热点问题页面布局与样式


<view class="mw-page"><view class="padding"><view class="padding-bottom-xs"><text class="text-bold text-lg">今日热点</text></view><view class="padding-bottom-xs"><text class="text-lg">{{detailInfo.question}}</text></view></view><view class="mw-content"><view class="padding"><text class="text-lg">{{detailInfo.answer}}</text></view></view><view class='padding'><button class="cu-btn sm round margin-right-sm {{detailInfo.isSubscribe?'bg-sky':'line-sky'}}" bindtap="alertFunc" data-id="{{detailInfo._id}}" data-index="{{index}}"> <text class="icon-appreciate"></text> 点赞</button><button class="cu-btn sm round margin-right-sm {{detailInfo.isCollected?'bg-sky':'line-sky'}}" bindtap="collectFunc" data-id="{{detailInfo._id}}" data-index="{{index}}"> <text class="icon-favor"></text> 收藏</button><button class="cu-btn sm round line-sky" open-type="share"> <text class="icon-share"></text> 分享</button></view>
</view>

page{background-color: #fff;
}
.mw-bg {position: absolute;top: 0;left: 0;width: 750rpx;height: 100vh;
}
.mw-btn {position: absolute;bottom: 10rpx;left: 0;width: 750rpx;z-index: 2;
}
.mw-answer {padding: 100rpx 150rpx 30rpx;
}
.mw-content {padding-bottom: 10rpx;border-top: 10rpx solid #eee;
}
.mw-banner {width: 100%;
}.comments-box {border-top: 10rpx solid #eee;padding: 30rpx 20rpx 10rpx;
}
.collect-btn {display: inline-block;padding-right: 20rpx;
}.collect-btn .lg {font-size: 36rpx;
}/* 评论区 */
.infoTitle{font-size: var(--font-size-M);font-weight: 600;color: #000;margin-bottom: 20rpx;
}
.van-cell{padding: 10rpx 0 10rpx 0 !important;/* position: relative;left: -26rpx; *//* font-size: var(--font-size-S); */
}.noComment{/* text-align: center; */color: #868688;margin-top: 50rpx;margin-bottom: 50rpx;
}.comment{background-color: #F2F1F6;margin-top: var(--font-size-M);padding: var(--font-size-S);border-radius: var(--font-size-S);
}.comment_time{color: #868688;display: inline-block;float: right;
}.comment_nickName{display: inline-block;color: #868688;
}.comment_text{font-size: 25rpx;color: #454547;
}.commentShell {margin-top: 50rpx;height: var(--font-size-M);margin-bottom: 100rpx;
}.inputComment{border: var(--color-theme) 1px solid;border-radius: var(--font-size-S);overflow: hidden;width: 95%;
}/* 评论按钮 */
.submitComment{display: inline-block;
}

支持点赞、收藏与分享功能

问答页面布局与样式


<view class="mw-page"><image src="/image/b1.jpg" mode='widthFix' class="banner"></image><view class="cu-bar search bg-white margin-top padding-lr"><view class='search-form round'><text class="icon-search"></text><input type="text" placeholder="请输入您的问题" confirm-type="search" value="{{ keyword }}" bindconfirm="onConfirm" bindinput="bindKeyInput" bindblur="bindblurFn"></input></view><view class='action'><button class='cu-btn bg-sky shadow-blur round' bind:tap="submit">提交</button></view></view><view class="mw-content padding-bottom"><view class="cu-bar bg-white padding-top-sm"><view class='action'><text class='icon-titles text-blue'></text><text class='text-xl text-bold'>专项考试</text></view></view><view class='grid col-2 padding-left-sm padding-right-sm'><view class='padding-sm' bindtap="goToAnswer" data-category="网络诈骗防范"><view class='bg-yellow padding radius shadow-warp'><view class="text-lg">网络诈骗防范</view><view class='margin-top-sm text-Abc'>共390题</view></view></view><view class='padding-sm' bindtap="goToAnswer" data-category="数据安全"><view class='bg-orange padding radius shadow-warp'><view class="text-lg">数据安全</view><view class='margin-top-sm text-Abc'>共210题</view></view></view><view class='padding-sm' bindtap="goToAnswer" data-category="密码安全"><view class='bg-olive padding radius shadow-warp'><view class="text-lg">密码安全</view><view class='margin-top-sm text-Abc'>共260题</view></view></view><view class='padding-sm' bindtap="goToAnswer" data-category="网络防御"><view class='bg-cyan padding radius shadow-warp'><view class="text-lg">网络防御</view><view class='margin-top-sm text-Abc'>共230题</view></view></view>      </view><view class='padding-left-sm padding-right-sm'><view class='padding-sm' bindtap="goToAnswer" data-category="安全培训和意识教育‌"><view class='bg-yellow padding radius shadow-warp'><view class="text-lg">安全培训和意识教育‌</view><view class='margin-top-sm text-Abc'>共330题</view></view></view></view></view>
</view>

page{background-color: #fff;
}
.banner {width: 100%;
}
.mw-bg {position: absolute;top: 0;left: 0;width: 750rpx;height: 100vh;
}
.mw-btn {position: absolute;bottom: 10rpx;left: 0;width: 750rpx;z-index: 2;
}
.mw-answer {padding: 100rpx 150rpx 30rpx;
}

答题页面布局与样式

<!--pages/test/test.wxml-->
<view class="page"><view class="flex flex-wrap solids-bottom padding-bottom"><view class='basis-xs'><view class="cu-avatar round lg margin-left"><image class="avatar" src="{{userInfo.avatarUrl}}" mode="widthFix"></image></view></view><view class='basis-xl'><view class="padding-top text-bold text-black">{{userInfo.nickName}}</view></view></view><view class="text-center padding-top">第<text class="text-xl text-bold">{{index+1}}</text>题共<text class="text-xl text-bold">{{questionList.length}}</text>题</view><view class='padding page-hd'><view class="page-title"><text class="text-bold">【{{questionList[index].type == 1?"单选题":questionList[index].type == 2?"多选题":"判断题"}}】</text>{{questionList[index].question}}</view></view><view class="page-bd"><radio-group class="radio-group" bindchange="radioChange" wx:if="{{questionList[index].type == 1 || questionList[index].type == 3}}"><label class="radio my-choosebox" wx:for="{{currQuestionOp}}" wx:for-index="key" wx:for-item="value" wx:key="index"><radio value="{{key}}" checked="{{questionList[index].checked}}" /><text class="margin-left-xs">{{key}}、{{value}}</text></label></radio-group><checkbox-group class="checkbox-group" bindchange="checkboxChange" wx:elif="{{questionList[index].type == 2}}"><label class="checkbox my-choosebox" wx:for="{{questionList[index].option}}" wx:for-index="key"  wx:for-item="value" wx:key="index"><checkbox value="{{key}}" checked="{{questionList[index].checked}}" /><text class="margin-left-xs">{{key}}、{{value}}</text></label></checkbox-group></view><view class='page-ft flex flex-direction padding padding-bottom-xl' wx:if="{{isOk}}"><button bindtap='okFunc' class="cu-btn lg round bg-sky" wx:if="{{index == questionList.length-1}}">提交</button><button bindtap='nextFunc' class="cu-btn lg round bg-sky" wx:else>下一题</button></view><view class='page-ft flex flex-direction padding padding-bottom-xl' wx:else><button bindtap='okFunc' class="cu-btn lg round bg-sky">确定</button></view><view wx:if="{{isOk}}"><view class='padding-bottom page-hd padding-top solids-top'><view class="page-title"><text class="text-bold">【正确答案】</text>{{questionList[index]['true']}}</view></view><view class='padding-bottom page-hd'><view class="page-title"><text class="text-bold">【解析】</text>{{questionList[index].analysis || '暂无'}}</view></view></view></view>

/* pages/test/test.wxss */
page {background-color: #fff;
}
.page {padding: 20rpx;
}
.page-bd {padding: 20rpx;
}
.page .radio-group, .page .checkbox-group {display: block;
}
.my-choosebox {display: block;margin-bottom: 20rpx;
}
.toindex-btn {margin-top: 20rpx;display:inline-block;line-height:2.3;font-size:13px;padding:0 1.34em;color: red;float: right;
}.collect {float:right;padding-right: 20rpx;
}.collect .lg {font-size: 36rpx;
}/* 评论区 */
.infoTitle{font-size: var(--font-size-M);font-weight: 600;color: #000;margin-bottom: 20rpx;
}
.van-cell{padding: 10rpx 0 10rpx 0 !important;/* position: relative;left: -26rpx; *//* font-size: var(--font-size-S); */
}.noComment{/* text-align: center; */color: #868688;margin-top: 50rpx;margin-bottom: 50rpx;
}.comment{background-color: #F2F1F6;margin-top: var(--font-size-M);padding: var(--font-size-S);border-radius: var(--font-size-S);
}.comment_time{color: #868688;display: inline-block;float: right;
}.comment_nickName{display: inline-block;color: #868688;
}.comment_text{font-size: 25rpx;color: #454547;
}.commentShell {margin-top: 50rpx;height: var(--font-size-M);margin-bottom: 100rpx;
}.inputComment{/* display: inline-block; *//* background-color: aqua; */border: var(--color-theme) 1px solid;border-radius: var(--font-size-S);overflow: hidden;width: 95%;
}/* 评论按钮 */
.submitComment{display: inline-block;/* align-items : center; *//* display: flex; *//* float: right; */ 
}

答题成绩页面布局与样式

<view class="page"><view class="padding"><view class="flex flex-wrap solids-bottom padding-bottom margin-bottom"><view class='basis-xs'><view class="cu-avatar round lg margin-left"><image class="avatar" src="{{userInfo.avatarUrl}}" mode="widthFix"></image></view></view><view class='basis-xl'><view class="text-bold text-black padding-left-xs padding-top">{{userInfo.nickName}}</view></view></view><view class='page-head'><view class="page-title padding-bottom-xs text-bold text-lg text-black">「{{category}}」专项考试</view><view>共{{totalQuestion}}题,满分100分</view><view class='page-score'><text class="score-num text-bold text-yellow">{{totalScore}}分</text></view></view><view class='page-footer'><view class='flex text-grey text-center margin-bottom padding bg-white radius'><view class='solid-right flex flex-direction flex-sub'><view class="text-green text-xxl">{{totalQuestion-wrong}}题</view><view class="margin-top-sm">答对</view></view><view class='solid-right flex flex-direction flex-sub'><view class="text-gray text-xxl">{{wrong}}题</view><view class="margin-top-sm">答错</view></view><view class='flex flex-direction flex-sub'><view class="text-xxl text-green">{{zql}}%</view><view class="margin-top-sm">正确率</view></view></view><view class="padding flex flex-direction"><button bindtap="toDoTestAgain" class="cu-btn lg round bg-sky"> 再答一次 </button><button bindtap="toIndex" class="cu-btn lg round line-sky margin-top"> 返回首页 </button><button class="cu-btn lg round line-sky margin-top" open-type="share"> 推荐给好友 </button></view></view></view></view>

/* pages/results/results.wxss */
page {background-color: #fff;
}
.page {padding: 30rpx;
}
.page-score {display: flex;justify-content: center;align-items: flex-end;padding-top:20rpx;
}
.mw-avatar {width: 128rpx;height: 128rpx;border-radius: 50%;overflow: hidden;
}
.page-footer {margin-top:30rpx;text-align: center;
}
.score-num {font-size:100rpx;
}

个人中心页面布局与样式

<view class='mw-page'><view class='UCenter-bg'><view class="margin-bottom"><view class="cu-avatar xl round"><image class="avatar" src="{{userInfo.avatarUrl}}" mode="widthFix"></image></view></view><view class='text-xl'>{{userInfo.nickName}}</view><view class='margin-top-sm'><text class="cu-tag bg-yellow">会员</text></view></view><view class="cu-list menu card-menu margin-top-xl"><view class="cu-item arrow"><navigator class='content' url='../rank/rank' hover-class='none'><text class='icon-rankfill text-sky'></text><text class='text-grey'>成绩排行榜</text></navigator></view><view class="cu-item arrow"><navigator class='content' url='../history/history' hover-class='none'><text class='icon-formfill text-sky'></text><text class='text-grey'>考试记录</text></navigator></view><view class="cu-item arrow"><navigator class='content' url='../myQuestionHistory/myQuestionHistory' hover-class='none'><text class='icon-commentfill text-sky'></text><text class='text-grey'>我的提问</text></navigator></view><view class="cu-item arrow"><navigator class='content' url='../myFavorites/myFavorites' hover-class='none'><text class='icon-favorfill text-sky'></text><text class='text-grey'>我的收藏</text></navigator></view><view class="cu-item arrow"><button class='cu-btn content' open-type='share'><text class='icon-appreciatefill text-sky'></text><text class='text-grey'>推荐给好友</text></button></view><view class="cu-item arrow"><navigator class='content' url='../guide/guide' hover-class='none'><text class='icon-creativefill text-sky'></text><text class='text-grey'>使用说明</text></navigator></view></view></view>

page {background-color: #f1f1f1;padding-bottom: 30rpx;
}
.UCenter-bg {/* background-color: #4975f2; */background-color: #446fea;background-size: cover;height: 450rpx;display: flex;justify-content: center;padding-top: 40rpx;overflow: hidden;position: relative;flex-direction: column;align-items: center;color: #fff;font-weight: 300;text-shadow: 0 0 3px rgba(0, 0, 0, 0.3);
}.UCenter-bg text {opacity: 0.8;
}.UCenter-bg image {width: 200rpx;height: 200rpx;
}.UCenter-bg .gif-wave{position: absolute;width: 100%;bottom: 0;left: 0;z-index: 99;mix-blend-mode: screen;  height: 100rpx;   
}map,.mapBox{left: 0;z-index: 99;mix-blend-mode: screen;  height: 100rpx;   
}map,.mapBox{width: 750rpx;height: 300rpx;
}.mw-weixin.text-center {color: rgb(230, 230, 230);padding: 30rpx 0 0;
}

排行榜

答题记录

打完收工。。

相关文章:

网络安全知识问答微信小程序的设计与实现

网络安全知识问答微信小程序的设计与实现&#xff0c;说白了&#xff0c;就是搭建一款网络安全知识问答微信小程序&#xff0c;类似网络安全百科直通车。三步走。 需求沟通 进行需求沟通&#xff0c;此处省略1000字。 画草图 根据沟通的需求&#xff0c;进行整理&#xff0c…...

Canvas特效实例:黑客帝国-字母矩阵(字母雨)

黑客帝国-字幕矩阵&#xff08;字母雨&#xff09; 效果预览代码实现思路解析遗留问题 效果预览 话不多说&#xff0c;我们直接上效果&#xff1a;当页面加载完成&#xff0c;屏幕上会落下如瀑布般的绿色字母流&#xff0c;不断向下滑动&#xff0c;仿佛进入了黑客帝国的数字世…...

「Mac畅玩AIGC与多模态11」开发篇07 - 使用自定义名言插件开发智能体应用

一、概述 本篇介绍如何在 macOS 环境下,通过编写自定义 OpenAPI Schema,将无需认证的名言服务接入 Dify 平台,并开发基于外部公共数据的智能体应用。本案例继续实践 GET 请求型 API 的实际调用技巧。 二、环境准备 1. 确认本地开发环境 macOS 系统Dify 平台已部署并可访问…...

快速上手非关系型数据库-MongoDB

简介 MongoDB 是一个基于文档的 NoSQL 数据库&#xff0c;由 MongoDB Inc. 开发。 NoSQL&#xff0c;指的是非关系型的数据库。NoSQL有时也称作Not Only SQL的缩写&#xff0c;是对不同于传统的关系型数据库的数据库管理系统的统称。 MongoDB 的设计理念是为了应对大数据量、…...

响应式布局,在飞帆平台中如此简单

这些控件都是可以自己动手去实现的。也可以将这些控件复制到自己名下进行修改。 响应式布局https://fvi.cn/782...

UN R79 关于车辆转向装置形式认证的统一规定(正文部分1)

UN R79法规是针对转向装置的型式认证法规&#xff0c;涉及A/B1/C类的横向控制辅助驾驶功能&#xff0c;对各功能的功能边界、性能要求、状态提示、故障警示以及型式认证要提交的信息做了规范&#xff0c;本文结合百度文心一言对法规进行翻译&#xff0c;并结合个人理解对部分内…...

深度学习系统学习系列【1】之基本知识

文章目录 说明基础知识人工智能、机器学习、深度学习的关系机器学习传统机器学习的缺陷选择深度学习的原因深度学习的关键问题深度学习的应用深度学习的加速硬件GPU环境搭建主流深度学习框架对比 说明 文章属于个人学习笔记内容&#xff0c;仅供学习和交流。内容参考深度学习原…...

python3GUI--视频监控管理平台 By:PyQt5(详细讲解)

文章目录 一&#xff0e;前言二&#xff0e;相关知识1.PyQt52.RTSP协议&#x1f4cc; 简介&#xff1a;&#x1f9e9; 特点&#xff1a;&#x1f4e1; 工作方式&#xff1a; 2. **RTMP&#xff08;Real-Time Messaging Protocol&#xff09;**&#x1f4cc; 简介&#xff1a;&a…...

第十一届蓝桥杯 2020 C/C++组 既约分数

目录 题目&#xff1a; 题目描述&#xff1a; 题目链接&#xff1a; 思路&#xff1a; 核心思路&#xff1a; 思路详解&#xff1a; 代码&#xff1a; 代码详解&#xff1a; 题目&#xff1a; 题目描述&#xff1a; 题目链接&#xff1a; 既约分数 - 蓝桥云课 思路&a…...

如何让Steam下载速度解除封印?!

平时一直没注意到家里的路由器在偷懒。最近成功榨干家里的带宽&#xff0c;把平时一直20mb/s左右下载速度的路由器一番改造后成功steam下载速度稳定85Mb/s。平时一直都只发挥了他的1/3不到&#xff0c;真是太可惜了。 硬件 首先检查硬件&#xff0c;就千兆路由器而言&#xf…...

HOOK上瘾思维模型——AI与思维模型【88】

一、定义 HOOK上瘾思维模型是一种通过设计一系列的触发&#xff08;Trigger&#xff09;、行动&#xff08;Action&#xff09;、奖励&#xff08;Reward&#xff09;和投入&#xff08;Investment&#xff09;环节&#xff0c;来促使用户形成习惯并持续使用产品或服务的思维框…...

基于开源AI智能名片链动2+1模式S2B2C商城小程序的IP开发泡沫破局与价值重构研究

摘要&#xff1a;当前IP开发领域普遍存在"冒进式泡沫"现象&#xff0c;企业将初级IP包装为超级IP运营&#xff0c;导致资源错配与价值虚化。本文通过实证分析开源AI智能名片链动21模式S2B2C商城小程序的技术架构与商业逻辑&#xff0c;揭示其通过智能内容引擎、合规化…...

深⼊理解指针(8)

1.对上一篇的补充内容 typedef int* ptr_t #define PTR_T int* 这两种写法都是可以的 ptr_t p1, p2; //p1, p2 都是指针变量 PTR_T p3, p4; //p3 是指针变量, p4是整型变量 为什么p3 是指针变量, p4是整型变量呢&#xff1f; 因为PTR_T 真的被改为了 int* 在编译器中…...

【iview】icon样式

A. 工程中引入样式文件 iview源码工程中的example工程中如何引入iview样式 image.png 自定义工程中如何引入iview样式 一般在src/main.js中引入&#xff08;在index.html中也可以&#xff0c;当然app.vue中也可以&#xff09; import "iview/dist/styles/iview.css"B…...

【计算机视觉】三维视觉:Nerfstudio:模块化神经辐射场框架的技术突破与实战指南

深度解析Nerfstudio&#xff1a;模块化神经辐射场框架的技术突破与实战指南 技术架构与核心创新系统架构设计关键技术特性 环境配置与安装指南硬件要求全平台安装流程 实战全流程解析1. 数据采集与预处理2. 模型训练与优化3. 可视化与导出 核心技术深度解析1. 混合表示网络2. 渐…...

第二章 OpenCV篇-图像阈值的综合操作-Python

目录 一.图像阈值 二.图像平滑 1.均值滤波 2.方框滤波 3.高斯滤波 4.中值滤波 5.双边滤波 此章节主要讲解&#xff1a;图像阈值、图像平滑处理、均值滤波、方框滤波、高斯滤波、中值滤波、双边滤波。 这里先讲作者使用matplotlib模块出现错误的解决方法。 首先作者在这…...

WPF处理大规模激光数据计算与安全传输处理

WPF大规模激光数据处理与安全传输系统设计方案 一、系统架构设计 1. 整体架构 ┌─────────────────────────────────────────────┐ │ WPF客户端应用 │ ├───────────────┬…...

vue 常见ui库对比(element、ant、antV等)

Element UI 1. 简介 Element UI 是一个基于 Vue 2 和 Vue 3 的企业级 UI 组件库&#xff0c;提供了丰富的组件和主题定制功能。官方网站&#xff1a;Element UI 2. 主要特点 丰富的组件&#xff1a;包括表单、表格、布局、导航、弹窗等多种组件。主题定制&#xff1a;支持主…...

【c++】【STL】stack详解

目录 stack类的作用什么是容器适配器stack的接口构造函数emptysizetoppushpopswap关系运算符重载 stack类的实现 stack类的作用 stack是stl库提供的一种容器适配器&#xff0c;也就是我们数据结构中学到的栈&#xff0c;是非常常用的数据结构&#xff0c;特点是遵循LIFO&#…...

单片机-89C51部分:12 pwm 呼吸灯 直流电机

飞书文档https://x509p6c8to.feishu.cn/wiki/JkzfwSoFBiUKc4kh8IoccTfyndg 一、什么是PWM&#xff1f; PWM是脉冲宽度调制的缩写&#xff0c;它是一种通过调整脉冲信号的高电平和低电平时间比例来控制电路输出的技术。简单来说&#xff0c;PWM是一种控制电子设备输出电压或电…...

WPF实现数据库操作与日志记录

1. 数据库操作实现 1.1 数据库连接基类 public abstract class DatabaseBase : IDisposable {protected string ConnectionString { get; }protected IDbConnection Connection { get; private set; }protected DatabaseBase(string connectionString){ConnectionString = co…...

用spring-boot-maven-plugin打包成单个jar有哪些缺点优化方案

Spring Boot 的 Fat JAR&#xff08;通过 spring-boot-maven-plugin 打包&#xff09;虽然简化了部署&#xff0c;但也存在一些潜在缺点&#xff0c;需根据场景权衡&#xff1a; 1. 启动速度较慢 原因&#xff1a; Fat JAR 需要在启动时解压并加载所有依赖的 JAR 文件到类路径…...

Spring Boot 使用 WebMagic 爬虫框架入门

1. 创建 Spring Boot 项目 使用 Spring Initializr 创建一个 Spring Boot 项目&#xff0c;选择需要的依赖&#xff0c;如 Spring Web 等。 2. 添加 WebMagic 依赖 在项目的 pom.xml 文件中添加 WebMagic 的核心和扩展依赖&#xff1a; <dependency><groupId>u…...

【软件设计师:复习】上午题核心知识点总结(二)

一、计算机网络(常考) 1.网络模型与协议(必考) 1.OSI七层模型 vs. TCP/IP四层模型 OSI七层TCP/IP四层核心协议/设备功能应用层(Application)应用层HTTP、FTP、DNS、SMTP提供用户接口和服务表示层(Presentation)SSL/TLS、JPEG、ASCII数据格式转换、加密/解密会话层(S…...

TensorRt10学习第一章

建立TensorRt时必须要有Public ILogger,因为createInferBuiler和createruntime要用&#xff0c;是一个接口 出错打印 和...

【LeetCode Hot100】回溯篇

前言 本文用于整理LeetCode Hot100中题目解答&#xff0c;因题目比较简单且更多是为了面试快速写出正确思路&#xff0c;只做简单题意解读和一句话题解方便记忆。但代码会全部给出&#xff0c;方便大家整理代码思路。 46. 全排列 一句话题意 给定一个无重复数字的序列&#xf…...

Go 语言中一个功能强大且广泛使用的数据验证库github.com/go-playground/validator/v10

github.com/go-playground/validator/v10 是 Go 语言中一个功能强大且广泛使用的数据验证库&#xff0c;主要用于对结构体字段进行数据校验&#xff0c;确保数据的合法性和完整性。以下是其核心作用、使用场景及代码案例的详细说明&#xff1a; 核心作用 数据校验 支持对结构体…...

Java 多线程进阶:线程安全、synchronized、死锁、wait/notify 全解析(含代码示例)

在 Java 并发编程中&#xff0c;“线程安全” 是核心议题之一。本文将深入讲解线程安全的实现手段、synchronized 的使用方式、可重入锁、死锁的成因与避免、wait/notify 通信机制等&#xff0c;并配合实际代码案例&#xff0c;帮助你彻底搞懂 Java 线程协作机制。 一、线程安全…...

windows电脑端SSH连接开termux的安卓端

&#xff08;确保你此前已经安装好了ssh&#xff09;在手机termux当中输入&#xff1a; 查看状态&#xff1a;ssh 启动服务&#xff1a;sshd 查看IP&#xff1a;ifconfig 然后在电脑端&#xff1a;...

Java 期中考试练习题

一、引言 Java 作为一门广泛应用的编程语言&#xff0c;在计算机相关专业的课程体系中占据重要地位。期中考试是检验同学们对 Java 知识掌握程度的重要环节。本文将呈现一些典型的 Java 期中考试试题&#xff0c;并进行详细讲解&#xff0c;希望能帮助大家更好地理解和掌握 Ja…...

【Unity】 组件库分类详解

1️⃣ Audio&#xff08;音频组件&#xff09; 用于处理游戏中的声音。 Audio Source 读音[ˈɔːdiəʊ ˈsɔːs]&#xff0c;音频源组件&#xff0c;用于播放音频文件&#xff0c;可设置音量、Pitch、循环播放等属性&#xff0c;是音频播放的核心组件。 Audio Listener 读音…...

Java 中使用正则表达式

1. 引入包 在使用正则表达式之前&#xff0c;需要引入包&#xff1a; import java.util.regex.Matcher; import java.util.regex.Pattern; 2. 常用模式规则 元字符 &#xff1a;这些是正则表达式中的特殊字符&#xff0c;用于匹配特定的模式。 . &#xff1a;匹配任意单个字…...

如何降低LabVIEW开发费用

在 LabVIEW 开发过程中&#xff0c;开发费用是用户和开发者共同关注的重点。过高的开发成本可能会压缩项目利润空间&#xff0c;甚至影响项目的可行性。下面将介绍降低 LabVIEW 开发费用的有效方法。 ​ 合理规划项目需求&#xff0c;避免后期增加​ 在项目启动阶段&#xff…...

WPF使用SQLSugar和Nlog

WPF应用中使用SQLSugar和NLog实现数据库操作与日志记录 1. 准备工作 首先,通过NuGet安装必要的包: Install-Package SQLSugarCore Install-Package NLog Install-Package NLog.Config Install-Package NLog.Targets.File 2. 配置NLog 在项目中添加nlog.config文件: <…...

Python10天冲刺-设计模型之策略模式

策略模式是一种行为设计模式&#xff0c;它允许你在运行时动态地改变对象的行为。这种模式的核心思想是将一组相关的算法封装在一起&#xff0c;并让它们相互替换。 下面是使用 Python 实现策略模式的一个示例&#xff1a; 示例代码 假设我们有一个简单的购物车系统&#xf…...

Js扩展DOM、BOM、AJAX、事件、定时器

BOM 操作 BOM指的是浏览器对象模型&#xff1a;Browser Object Mode&#xff0c;通过操作 window 对象的属性和方法来实现与浏览器的交互。 BOM的构成如下图所示&#xff1a; 其中&#xff0c;window对象是顶级对象&#xff0c;在 window 对象下面有一些重要的属性&#xff1…...

奥地利学派方法论的三个基础

主观价值论&#xff1a; 一切估价行为皆来自于个人&#xff0c;价格现象只能从主观估价中得到解释。 个人只在边际上做决策&#xff0c;边际价值是递减的。 罗斯巴德的等式&#xff1a;三个单位的某个东西的总效用 > 两个单位的总效用 > 一个单位的总效用&#xff0c;但…...

WPF之Image控件详解

文章目录 1. 概述2. Image控件的基本属性2.1 Source属性2.2 Stretch属性2.3 StretchDirection属性 3. 在XAML中使用Image控件3.1 基本用法3.2 设置拉伸模式3.3 设置图像对齐方式 4. 在代码中操作Image控件4.1 加载本地图像4.2 异步加载图像4.3 从流中加载图像4.4 控制图像的解码…...

如何将 VS Code 与 Linux 系统高效连接:从入门到进阶

引言 无论是开发服务器应用、管理远程主机&#xff0c;还是在本地 Linux 环境中提升开发效率&#xff0c;Visual Studio Code&#xff08;VS Code&#xff09; 凭借其强大的扩展能力&#xff0c;成为连接 Linux 系统的利器。本文将详细介绍 三种主流方法&#xff0c;助你无缝对…...

Matlab/Simulink - BLDC直流无刷电机仿真基础教程(五) - animateRotorPosition脚本讲解与使用

Matlab/Simulink - BLDC直流无刷电机仿真基础教程&#xff08;五&#xff09; - animateRotorPosition脚本讲解与使用 前言一、animateRotorPosition脚本内容二、脚本功能讲解三、脚本修改与模型配置四、可视化效果展示五、修改后脚本内容文章相关模型文件下载链接参考链接 前言…...

安川机器人常见故障报警及解决办法

机器人权限设置 操作权限设置(如果密码不对,就证明密码被人修改) 编辑模式密码:无(一把钥匙,默认) 管理模式密码:999999999(9个9,二把钥匙) 安全模式密码:555555555(9个5,三把钥匙,权限最高,有的型号机器人,没有此模式,但最高密码为安全模式密码) 示教器…...

【Quest开发】极简版!透视环境下抠出身体并能遮挡身体上的服装

前两天发了一个很复杂的版本&#xff0c;又鼓捣了一下发现完全没有必要。我之前的理解有点偏&#xff08;不是错误的但用法错了&#xff09;&#xff0c;但是有一些小伙伴收藏了&#xff0c;害怕里面的某些东西对谁有用&#xff0c;所以写了一篇新的&#xff0c;前两步配置环境…...

【Github仓库】Learn-Vim随笔

一、前言 学习vim的过程中发现了很多很好的资源&#xff0c;其中不乏bilibili上up主的精品教程。也在YouTube上看过很多教程。但Learn-Vim这个Github仓库实在让我受益良多。 本笔记便是出于此仓库&#xff1a; 仓库地址 附上个人.vimrc配置文件: syntax on " 开启语法高…...

【2025五一数学建模竞赛C题】社交媒体平台用户分析问题|建模过程+完整代码论文全解全析

你是否在寻找数学建模比赛的突破点&#xff1f;数学建模进阶思路&#xff01; 作为经验丰富的美赛O奖、国赛国一的数学建模团队&#xff0c;我们将为你带来本次数学建模竞赛的全面解析。这个解决方案包不仅包括完整的代码实现&#xff0c;还有详尽的建模过程和解析&#xff0c…...

Wireshark抓取SMTP协议报文

文章目录 1. 实验&#xff1a;网络仿真软件使用及网络分析2. SMTP协议2.1 SMTP协议简介2.2 SMTP协议的核心功能2.3 SMTP的相关命令和作用 3. Wireshark抓取报文3.1 抓取SMTP协议报文流程3.1.1 Email邮件服务器背景3.1.2 具体实现流程 3.2 过滤SMTP协议相关报文 4. 协议时序图4.…...

PS学习笔记(一)

课程地址&#xff1a;【B站第一&#xff01;】央美大佬198小时讲完的PS教程&#xff0c;全程干货无废话&#xff01;学完秒变大神&#xff01;还学不会&#xff0c;我不教设计了&#xff01;&#xff01;_哔哩哔哩_bilibili 第一章&#xff1a;基础知识 1.PS认识 一、PS应用领…...

部署.NET6.0 Web API项目到Docker

文章目录 介绍创建.NET WebAPI项目项目打包项目部署文件准备部署命令可能的问题与解决 介绍 使用VS2022创建一个.NET6的Web API项目&#xff0c;将其打包&#xff0c;并部署到Linux服务器上的Docker中。 Linux和Docker环境已经备好&#xff0c;本文不再赘述&#xff0c;主要记…...

前端函数防抖(Debounce)完整讲解 - 从原理、应用到完整实现

&#x1f337; 古之立大事者&#xff0c;不惟有超世之才&#xff0c;亦必有坚忍不拔之志 &#x1f390; 个人CSND主页——Micro麦可乐的博客 &#x1f425;《Docker实操教程》专栏以最新的Centos版本为基础进行Docker实操教程&#xff0c;入门到实战 &#x1f33a;《RabbitMQ》…...

React Redux 与 Zustand

Redux 一、Redux 核心概念 1. 为什么需要 Redux&#xff1f; 解决的问题&#xff1a;在大型 React 应用中&#xff0c;跨组件共享状态、管理复杂数据流。 优势&#xff1a; 单一数据源&#xff1a;全局状态集中存储在 Store 中。 可预测性&#xff1a;通过严格的规则&#…...

Webug4.0靶场通关笔记07- 第9关反射XSS和第10关存储XSS

目录 第09关 反射型XSS 1.打开靶场 2.源码分析 3.渗透实战 第10关 存储型XSS 1.打开靶场 2.源码分析 3.渗透实战 本系列为通过《Webug4.0靶场通关笔记》的渗透集合&#xff0c;本文为反射型和存储型XSS漏洞关卡的渗透部分&#xff0c;通过对XSS关卡源码的代码审计找到漏…...