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

仿infobip模板功能-可通过占位符配置模板内容

模仿infobip制作的模板功能,正文可在任意位置加参数的功能。如下图所示:在正文中通过{{\d}}进行占位,在使用模板时,可在此位置自定制内容,并预览效果。
在这里插入图片描述
代码:

<template><div class="template-body-wrapper"><div class="textarea-box"><el-form :model="formData":rules="bodyRules"ref="textForm"><div class="edit-content"><divcontenteditable="true" @blur="handleBlur"ref="editor"class="iscroll edit-wrapper"@keyup="getCursor" @click="getCursor"@input="getWordNum"id="contentEdit"placeholder="请输入消息"></div></div><div class="textarea-bottom"><el-popoverplacement="top-start"width="480"ref="pop"trigger="click"><div><emotion @handleEmotion="handleEmotion"></emotion></div><button type="button" class="button-no-style" slot="reference"><i class="hz-icon-weixiao"></i></button></el-popover><button type="text" class="d-value button-no-style" @click.prevent="addValue">{+}</button><span class="send-word-num" :class="wordNum>=1014?'active_word_num':''">{{wordNum}}/1024</span></div><el-form-itemprop="text"class="hide-form-item"><el-input v-model="formData.text" style="display: none;"></el-input></el-form-item></el-form></div><div class="tip-box"><div class="tip-item"v-for="(item, index) in bodyTips" :key="index">{{ item }}</div></div><el-form:model="dValue":rules="dValueRules"ref="dValueForm"><ul v-if="hasPlaceholder" class="d-value-list"><li v-for="(value, key, index) in dValue":key="index"class="d-value-item"><el-form-item:prop="key"><div>参数<font v-pre>{{</font>{{ key }}<font>}}</font><el-button type="text" @click="delDValue(key)" class="del-btn">删除</el-button></div><el-input v-model="dValue[key]" placeholder="输入样例内容"size="small"@input="initFormData"></el-input></el-form-item></li></ul></el-form></div>
</template><script>
import {emojiList} from '@/config/config'
import {emotionUrl} from "@/config/env";
import Emotion from '@/pages/wp/chat/component/Emotion.vue'
import { bodyTips, setCursorPosition, getCursorPosition } from "../data"
export default {props: {formData: {type: Object,default: () => ({})},},watch: {formData(val){let contentEdit = document.getElementById('contentEdit');contentEdit.innerHTML = val.textif(this.formData.examples){this.formData.examples.forEach((item, index) => {this.dValue[index+1+''] = item})}}},components: {Emotion},computed: {dValueRules(){let rules = {}Object.keys(this.dValue).forEach(key => {rules[key] = [{required: true, message: "请输入样例内容", trigger: "change"}]})return rules},},data(){return {wordNum: 0,bodyTips,hasPlaceholder: false,index: 1,dValue: {},bodyRules: {text: [{required: true, message: "请输入模板内容", trigger: "change"},{validator: this.validator, trigger: "change"}],examples: [{ required: true, message: "请输入样例内容", trigger: "change" }]},rules: {text: [{ required: true, message: "标题文本不能为空", trigger: "change" },{ validator: this.checkText, trigger: "change"}],}}},methods: {handleBlur(){},handleEmotion(index) {this.focuson()let _index = emojiList.indexOf(index);let src = `${emotionUrl}${_index}.png`;// document.execCommand("insertImage", false, src);document.execCommand("insertText", false, index);this.getWordNum()this.$refs.pop.showPopper = false;},focuson() {let contentEdit = document.getElementById('contentEdit');if (contentEdit.innerHTML == '') {contentEdit.focus();}else{contentEdit.innerHTML = contentEdit.innerHTML.replace(/&nbsp;/g, ' ').replace(/<div>/g,'\n').replace(/<\/div>/g,'').replace(/<br>/g, '\n')const len = contentEdit.innerHTML.lengthif(this.cursorPosition > len){this.cursorPosition = len}setCursorPosition( this.$refs.editor, this.cursorPosition)}},getWordNum(e) {let contentEdit = document.getElementById('contentEdit');let innerHtml = contentEdit.innerHTML;let imglist = innerHtml.match(/<img .*?src="(.*?)".*?\/?>/g);let text = innerHtml.replace(/<.*?>/g, "").replace(/&nbsp;/g, ' ');// let text = innerHtml.replace(/<.*?>/g,"");if (imglist) {this.wordNum = imglist.length + text.length;} else {this.wordNum = text.length;}let innerLength = innerHtml.length;if (this.wordNum > 1024) {this.moreInnerHtml = innerHtml.substr(0, innerLength - 1)e.target.innerHTML = '';document.execCommand('insertHTML', false, innerHtml.substr(0, innerLength - 1));}this.NoNumText = text.replace(/[0-9]/ig, "");this.getText()},//获取光标的位置getCursor () {this.editEle = this.$refs.editorthis.cursorPosition = getCursorPosition(this.editEle);},addValue(){this.focuson()document.execCommand('insertText', false, `{{${Object.keys(this.dValue).length+1}}}`);this.cursorPosition += (Object.keys(this.dValue).length+1+'').length + 4},delDValue(index){let contentEdit = document.getElementById('contentEdit');let text = contentEdit.innerHTML.replace(`{{${index}}}`, '')contentEdit.innerHTML = textthis.getText()delete this.dValue[index]setCursorPosition(this.$refs.editor)},validator(rule, value, callback){const matchs = value.match(/\{\{(.*?)\}\}/g)if(matchs){// 顺序要对 必须是1 2 3 4... 不能是4 5 6(缺数), 不能是3 2 1 4 5(乱序)const indexs = matchs.map(item => {return item.slice(2, -2)})// 判断是否是一个从1开始递增(低增值为1)的数组const isValid = indexs.every((item, index) => {return item - index === 1})if(isValid){this.setPlaceHolderValue(indexs)callback()this.hasPlaceholder = true}else{this.resetPlaceHolderValue()callback(new Error('无效占位符顺序'))}}else{callback()this.hasPlaceholder = falsethis.dValue = {}this.initFormData()}},setPlaceHolderValue(arr){let obj = {}arr.forEach((item, index) => {obj[item+''] = this.dValue[item+'']})this.dValue = objthis.initFormData()},resetPlaceHolderValue(){this.hasPlaceholder = falsethis.dValue = {}this.initFormData()this.getText()this.formData.examples = []},// 获取formData数据getText(){const contentEdit = document.getElementById('contentEdit');const text = contentEdit.innerHTML.replace(/&nbsp;/g, ' ').replace(/<div>/g,'\n').replace(/<\/div>/g,'').replace(/<br>/g, '\n')this.formData.text = text    },initFormData(){this.formData.examples = Object.keys(this.dValue).map(key => this.dValue[key])},validate(){return Promise.all([this.$refs.textForm.validate(),this.$refs.dValueForm.validate()]).then(([res1, res2]) => {return res1 && res2})}},
}
</script><style lang="scss">
.template-body-wrapper{.textarea-box{border: 1px solid #DCDFE6;width: 100%;margin-bottom: 20px;textarea{border-radius: 0;border: none;border-bottom: 1px solid #DCDFE6!important;}.el-form .hide-form-item{margin: 0;}}.el-textarea .el-input__count{position: absolute;bottom: -32px;}.edit-content {height: 100px;width: 100%;position: relative;.edit-wrapper {height: 100%;width: 100%;padding: 8px 12px;outline: none;overflow-y: auto;padding-bottom: 40px;line-height: 20px;vertical-align: top;font-size: 14px;&:empty:before {font-size: 14px;content: attr(placeholder);color: #bbb;}&:focus {content: none;}img {height: 30px;width: auto;display: inline-block;/*vertical-align: middle;*/}/*background: #ffffff;*/}.send-btn-box {display: inline-block;float: right;height: 30px;line-height: 30px;.send-tip {font-size: 12px;font-weight: 400;color: #90959E;line-height: 22px;margin-right: 8px;}.send-btn {margin-right: 8px;}}}.button-no-style{border: none;cursor: pointer;background: none;}.hz-icon-weixiao{font-size: 20px;}.d-value{font-size: 16px;line-height: 20px;vertical-align: text-bottom;background: none;}.textarea-bottom{border-top: 1px solid #DCDFE6;}.send-word-num {width: 42px;height: 30px;font-size: 12px;font-weight: 400;color: #90959E;line-height: 30px;margin-right: 12px;float: right;&.active_word_num {color: #E6A23C;}}.tip-item{color: #90959E;line-height: 30px;font-size: 12px;}.el-form-item{margin-bottom: 10px;}.del-btn{margin-left: 8px;}.edit-wrapper{white-space: pre-line;}
}
</style>

data/index.js

export const setCursorPosition = (element, cursorPosition) => {const range = document.createRange()const lastChild = element.lastChildif(lastChild.innerHTML){if(cursorPosition === undefined){range.setStart(lastChild.firstChild, lastChild.innerHTML.length)range.setEnd(lastChild.firstChild, lastChild.innerHTML.length)}else{range.setStart(lastChild.firstChild, cursorPosition)range.setEnd(lastChild.firstChild, cursorPosition)}}else{if(cursorPosition === undefined){range.setStart(lastChild, lastChild.length)range.setEnd(lastChild, lastChild.length)}else{range.setStart(lastChild, cursorPosition)range.setEnd(lastChild, cursorPosition)}}const sel = window.getSelection()sel.removeAllRanges()sel.addRange(range)
}export const getCursorPosition = (element) => {let caretOffset = 0const doc = element.ownerDocument || element.documentconst win = doc.defaultView || doc.parentWindowconst sel = win.getSelection()if (sel.rangeCount > 0) {const range = win.getSelection().getRangeAt(0)const preCaretRange = range.cloneRange()preCaretRange.selectNodeContents(element)preCaretRange.setEnd(range.endContainer, range.endOffset)const divs = preCaretRange.commonAncestorContainer.innerHTML.match(/<div>/g)const len = divs ? divs.length : 0caretOffset = preCaretRange.toString().length + len}return caretOffset
}

相关文章:

仿infobip模板功能-可通过占位符配置模板内容

模仿infobip制作的模板功能&#xff0c;正文可在任意位置加参数的功能。如下图所示&#xff1a;在正文中通过{{\d}}进行占位&#xff0c;在使用模板时&#xff0c;可在此位置自定制内容&#xff0c;并预览效果。 代码&#xff1a; <template><div class"templa…...

STM32第6章、WWDG

一、简介 WWDG&#xff1a;全称Window watchdog&#xff0c;即窗口看门狗&#xff0c;本质上是一个能产生系统复位信号和提前唤醒中断的计数器。 特性&#xff1a; 是一个递减计数器。 看门狗被激活后&#xff0c; 当递减计数器值从 0x40减到0x3F时会产生复位&#xff08;即T6位…...

没有正确使用HTTP Range Request,导致访问Azure Blob存储的视频没有实现流式播放

引文&#xff1a; 组里的小伙伴在修改视频播放相关的代码&#xff0c;修改之前的方案使用CDN转发&#xff0c;可以实现流式播放&#xff0c;修改之后的代码因为没有正确的使用Http Range Request, 导致画面访问Azure Blob存储的视频没有实现流式播放&#xff0c;整理下线索在这…...

React中Fiber树构建过程详解——react中render一个App组件(包含子组件)的流程详解

在 React 中&#xff0c;渲染一个包含子组件的组件涉及一系列底层流程&#xff0c;包括构建虚拟 DOM&#xff08;React Element&#xff09;、协调&#xff08;Reconciliation&#xff09;、Fiber 树管理和最终的 DOM 操作。以下是一个从底层解析的详细流程&#xff1a; 1. 初始…...

机器学习赋能的智能光子学器件系统研究与应用

在人工智能与光子学设计融合的背景下&#xff0c;科研的边界持续扩展&#xff0c;创新成果不断涌现。从理论模型的整合到光学现象的复杂模拟&#xff0c;从数据驱动的探索到光场的智能分析&#xff0c;机器学习正以前所未有的动力推动光子学领域的革新。据调查&#xff0c;目前…...

晨辉面试抽签和评分管理系统之七:面试成绩核算的三种方式

晨辉面试抽签和评分管理系统&#xff08;下载地址:www.chenhuisoft.cn&#xff09;是公务员招录面试、教师资格考试面试、企业招录面试等各类面试通用的考生编排、考生入场抽签、候考室倒计时管理、面试考官抽签、面试评分记录和成绩核算的面试全流程信息化管理软件。提供了考生…...

语音合成的预训练模型

语音合成的预训练模型 与 ASR(语音识别)和音频分类任务相比,语音合成的预训练模型检查点明显较少。在 Hugging Hub 上,可以找到近 300 个适合的检查点。 在这些预训练模型中,重点关注两种在 Huggingface Transformers 库中开箱即用的架构——SpeechT5 和 Massive Multili…...

Windows怎么搭建rust环境?

在Windows上搭建Rust开发环境相对简单&#xff0c;主要步骤如下&#xff1a; ### 1. 安装Rust 最简单的方法是使用官方提供的安装脚本。打开命令提示符&#xff08;Command Prompt&#xff09;或PowerShell&#xff0c;然后运行以下命令来下载并安装Rust&#xff1a; bash cu…...

【Flink】Flink内存管理

Flink内存整体结构图&#xff1a; JobManager内存管理 JVM 进程总内存(Total Process Memory)Flink总内存(Total Flink Memory)&#xff1a;JVM进程总内存减去JVM Metaspace(元空间)和JVM Overhead(运行时开销)上图解释&#xff1a; JVM进程总内存为2G;JVM运行时开销(JVM Overh…...

React方向:react中5种Dom的操作方式

1、通过原生JS获取Dom去操作 通过document.querySelector(#title)原生js的方式去拿到dom节点&#xff0c;然后去进行操作。 import {Component} from "react";class App extends Component {//定义获取Dom的函数handleGetDom(){let title document.querySelector(#t…...

K8s数据存储之详解(Detailed Explanation of K8s Data Storage)

K8s数据存储相关概念详解&#xff08;临时存储&#xff0c;节点存储&#xff0c;网络存储&#xff0c;PV/PVC&#xff09; 本篇文章分享一下存储卷和数据持久化的相关概念&#xff1a; 存储卷概述 临时存储卷&#xff08;Ephemeral Volumes&#xff09; 节点存储卷&#xff…...

PyTorch 中的 Dropout 解析

文章目录 一、Dropout 的核心作用数值示例&#xff1a;置零与缩放**训练阶段****推理阶段** 二、Dropout 的最佳使用位置与具体实例解析1. 放在全连接层后2. 卷积层后的使用考量3. BatchNorm 层与 Dropout 的关系4. Transformer 中的 Dropout 应用 三、如何确定 Dropout 的位置…...

计算机网络 (41)文件传送协议

前言 一、文件传送协议&#xff08;FTP&#xff09; 概述&#xff1a; FTP&#xff08;File Transfer Protocol&#xff09;是互联网上使用得最广泛的文件传送协议。FTP提供交互式的访问&#xff0c;允许客户指明文件的类型与格式&#xff08;如指明是否使用ASCII码&#xff0…...

AOSP 14及以上userdebug无法调试的问题

参考链接&#xff1a;原文...

【Vue】点击侧边导航栏,右侧main对应显示

需求&#xff1a;点击侧边导航栏&#xff0c;右侧main对应显示 通过v-if或v-show等指令来控制不同内容的显示隐藏来实现 注意&#xff1a; 使用v-if时候进行导航栏切换&#xff0c;右侧显示区域可能会出现样式错乱&#xff1b;使用v-show则不会出现此错误 <template>&…...

Python Selenium 库学习指南

Python Selenium 库学习指南 目录 Selenium 基础介绍 Selenium 是什么安装 SeleniumSelenium 的工作原理 Selenium 基本用法 启动浏览器定位元素常见操作&#xff1a;点击、输入、滚动 高级用法 切换窗口与标签页模拟鼠标操作与键盘输入动态加载的网页处理 等待机制 显式等待…...

如何解决Webview和H5缓存问题,确保每次加载最新版本的资源

WebView 用于加载 H5 页面是常见的做法&#xff0c;它能够加载远程的 HTML、CSS、JavaScript 资源&#xff0c;并且让 Web 应用嵌入到原生 App 中。然而&#xff0c;WebView 的缓存机制有时会导致用户看到的是旧版本的页面或资源&#xff0c;尤其是在 H5 发版后&#xff0c;iOS…...

costmap 中点与多边形的相对位置关系

一、背景 近期在阅读move_base源码costmap部分(感觉想玩转movebase导航&#xff0c;costmap必须理解呀)。读到两处点与多边形的相对位置关系。在此总结一下&#xff0c;分别是: intersects: 利用待测点向右引出的射线与多边形的交点数来确定相对位置。有的称 射线交叉算法&am…...

C#与Vue2上传下载Excel文件

1、上传文件流程&#xff1a;先上传文件&#xff0c;上传成功&#xff0c;返回文件名与url&#xff0c;然后再次发起请求保存文件名和url到数据库 前端Vue2代码&#xff1a; 使用element的el-upload组件&#xff0c;action值为后端接收文件接口&#xff0c;headers携带session信…...

.NetCore 使用 NPOI 读取带有图片的excel数据

在.NetCore使用NPOI插件进行批量导入时&#xff0c;获取Excel中的所有的图片数据&#xff0c;存到集合中。 1.定义类PictureData 代码如下&#xff1a; public class PictureData { public byte[] Data { get; set; } } 2.数据集引用 using NPOI.XSSF.UserModel; usin…...

鸿蒙打包发布

HarmonyOS应用/元服务发布&#xff08;打包发布&#xff09; https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V13/ide-publish-app-V13?catalogVersionV13 密钥&#xff1a;包含非对称加密中使用的公钥和私钥&#xff0c;存储在密钥库文件中&#xff0c;格式…...

C++并发编程之跨应用程序与驱动程序的单生产者单消费者队列

设计一个单生产者单消费者队列&#xff08;SPSC队列&#xff09;&#xff0c;不使用C STL库或操作系统原子操作函数&#xff0c;并且将其放入跨进程共享内存中以便在Ring3&#xff08;用户模式&#xff09;和Ring0&#xff08;内核模式&#xff09;之间传递数据&#xff0c;是一…...

22、PyTorch nn.Conv2d卷积网络使用教程

文章目录 1. 卷积2. python 代码3. notes 1. 卷积 输入A张量为&#xff1a; A [ 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ] \begin{equation} A\begin{bmatrix} 0&1&2&3\\\\ 4&5&6&7\\\\ 8&9&10&11\\\\ 12&13&14&15 \end{b…...

智汇云舟参编《城市轨道交通安全防范系统技术要求》国标正式发布

近日&#xff0c;根据国家标准化管理委员会官网&#xff0c;全国标准信息公共服务平台发布的公告&#xff0c;国家标准《城市轨道交通安全防范系统技术要求》&#xff08;GB/T 26718-2024&#xff09;已由全国城市轨道交通标准化技术委员会上报国家标准化管理委员会&#xff0c…...

C# 数据拟合教程:使用 Math.NET Numerics 的简单实现

C# 数据拟合实战&#xff1a;使用 Math.NET Numerics 快速实现 引言 在科学计算、工程建模或数据分析中&#xff0c;数据拟合是一个非常重要的技术。无论是线性拟合还是非线性拟合&#xff0c;借助适当的工具都可以快速解决问题。本文将向您展示如何使用 C# 和强大的数值计算…...

WEB攻防-通用漏洞_XSS跨站_权限维持_捆绑钓鱼_浏览器漏洞

目录 XSS的分类 XSS跨站-后台植入Cookie&表单劫持 【例1】&#xff1a;利用beef或xss平台实时监控Cookie等凭据实现权限维持 【例2】&#xff1a;XSS-Flash钓鱼配合MSF捆绑上线 【例3】&#xff1a;XSS-浏览器网马配合MSF访问上线 XSS的分类 反射型&#xff08;非持久…...

瑞芯微 RK 系列 RK3588 使用 ffmpeg-rockchip 实现 MPP 视频硬件编解码-代码版

前言 在上一篇文章中&#xff0c;我们讲解了如何使用 ffmpeg-rockchip 通过命令来实现 MPP 视频硬件编解码和 RGA 硬件图形加速&#xff0c;在这篇文章&#xff0c;我将讲解如何使用 ffmpeg-rockchip 用户空间库&#xff08;代码&#xff09;实现 MPP 硬件编解码。 本文不仅适…...

MySQL数据库(SQL分类)

SQL分类 分类全称解释DDLData Definition Language数据定义语言&#xff0c;用来定义数据库对象&#xff08;数据库&#xff0c;表&#xff0c;字段&#xff09;DMLData Manipulation Language数据操作语言&#xff0c;用来对数据库表中的数据进行增删改DQLData Query Languag…...

SpringBoot-Day1

1.Springboot入门 创建Maven工程 导入spring-boot-stater-web起步依赖 编写Controller 提供启动类 2.yml配置信息书写与获取 书写 # 发件人信息 email:user: 172349823457qq.comcode: sajdajlwhjfgfkllwhost: smtp.qq.comauth: true ​ # 学生爱好 hobbies:- 打篮球- 踢…...

【JavaScript】基础内容,HTML如何引用JavaScript, JS 常用的数据类型

HTML 嵌入 Javascript 的方式 引入外部 js 文件 <head> <script Language "javaScript" src"index.js"/> </head>内部声明 <head> <script language"javascript">function hello(){alert("hello word&qu…...

mysql中创建计算字段

目录 1、计算字段 2、拼接字段 3、去除空格和使用别名 &#xff08;1&#xff09;去除空格 &#xff08;2&#xff09;使用别名&#xff1a;AS 4、执行算术计算 5、小结 博主用的是mysql8 DBMS&#xff0c;附上示例资料&#xff1a; 百度网盘链接: https://pan.baidu.co…...

如何优化zibll子比主题SEO并设置有效robots文件

如果你不知道 robots.txt 是什么&#xff0c;也不确定如何正确地设置它&#xff0c;本篇文章会向您介绍适用于子比主题的 robots.txt 文件&#xff0c;利用它可以提升 SEO 的效果&#xff0c;避免收录无关页面&#xff0c;从而解决网站被收录但无权重的困境。 作为一款高效的 …...

线程间通信

线程间通信&#xff08;Inter-Thread Communication, 简称ITC&#xff09;是指在多线程编程中&#xff0c;不同线程之间如何交换信息或协调彼此的行为。良好的线程间通信机制是构建高效、可靠的并发程序的关键。Java语言提供了多种内置工具和库来支持线程间的通信&#xff0c;包…...

【实践】操作系统智能助手OS Copilot新功能测评

一、引言 数字化加速发展&#xff0c;尤其人工智能的发展速度越来越快。操作系统智能助手成为提升用户体验与操作效率的关键因素。OS Copilot借助语言模型&#xff0c;人工智能等&#xff0c;对操作系统的自然语言交互操作 推出很多功能&#xff0c;值得开发&#xff0c;尤其运…...

今年的电商年货节,主流的营销策略是怎样?

随着一年的年关将近&#xff0c;新一年的CNY营销也逐渐拉开帷幕。考虑到此时消费需求的膨胀&#xff0c;这个时间不论对于线上还是线下市场而言&#xff0c;都是重要的营销节点。今年CNY营销&#xff0c;电商平台上的主流营销策略是这样&#xff1f;就让我们来简单了解下概况。…...

Java设计模式——单例模式(特性、各种实现、懒汉式、饿汉式、内部类实现、枚举方式、双重校验+锁)

文章目录 单例模式1️⃣特性&#x1f4aa;单例模式的类型与实现&#xff1a;类型懒汉式实现(线程不安全)懒汉式实现(线程安全&#xff09;双重锁校验懒汉式(线程安全)饿汉式实现(线程安全)使用类的内部类实现⭐枚举方式实现单例&#xff08;推荐&#xff09;&#x1f44d; 单例…...

基于 Python 的学生成绩管理系统设计与实现

标题:基于 Python 的学生成绩管理系统设计与实现 内容:1.摘要 摘要&#xff1a;本文介绍了一个基于 Python 的学生成绩管理系统的设计与实现。该系统旨在提高学生成绩管理的效率和准确性&#xff0c;方便教师和学生进行成绩查询和分析。本文详细描述了系统的设计思路、功能模块…...

局域网共享文件夹实现两台Windows电脑之间传输文件

文章目录 1. 启用网络发现和文件共享2. 设置共享文件夹3. 记录主电脑的IP地址4. 在第二台电脑访问共享文件夹5. 故障排查6. 启用文件共享未生效方案1&#xff1a;检查服务状态方案2&#xff1a;检查防火墙设置方案3&#xff1a;检查网络类型方案4&#xff1a;使用“管理员命令提…...

JS的事件循环机制

<script>setTimeout(()>{console.log(1)},1000)setTimeout(()>{console.log(2)},3000)var start Date.now();while ( (Date.now() - start) < 10000 ){}console.log(3)</script>执行如下代码会发现先打印3&#xff0c;再打印1 再打印2。 现象本质还是因为…...

《自动驾驶与机器人中的SLAM技术》ch9:自动驾驶车辆的离线地图构建

目录 1 点云建图的流程 2 前端实现 2.1 前端流程 2.2 前端结果 3 后端位姿图优化与异常值剔除 3.1 两阶段优化流程 3.2 优化结果 ① 第一阶段优化结果 ② 第二阶段优化结果 4 回环检测 4.1 回环检测流程 ① 遍历第一阶段优化轨迹中的关键帧。 ② 并发计算候选回环对…...

环境搭建——Mysql、Redis、Rocket MQ部署

前言 在搭建分布式系统时&#xff0c;MySQL、Redis 和 RocketMQ 是常用的基础服务。每个服务各自的功能不同&#xff0c;但它们在数据存储、缓存、消息队列等方面不可或缺。如果你是初学者&#xff0c;别担心&#xff0c;本文会一步步详细教你如何在服务器上通过 Docker 部署这…...

Pycharm连接远程解释器

这里写目录标题 0 前言1 给项目添加解释器2 通过SSH连接3 找到远程服务器的torch环境所对应的python路径&#xff0c;并设置同步映射&#xff08;1&#xff09;配置服务器的系统环境&#xff08;2&#xff09;配置服务器的conda环境 4 进入到程序入口&#xff08;main.py&#…...

git的基本操作

创建分支&#xff1a; 1&#xff0c;拉去develop代码&#xff1b; 2&#xff0c;git checkout develop切换到develop&#xff1b; 3&#xff0c;git branch lyb/lyb_develop &#xff1b; 4&#xff0c;git push --set-upstream origin lyb/lyb_develop 切换分支&#xff0c;上…...

Linux软件包管理工具概览

目录 RPM&#xff08;RedHat Package Manager&#xff09; DPKG&#xff08;Debian Packager&#xff09; APT&#xff08;Advanced Package Tool&#xff09; YUM&#xff08;Yellowdog Updater, Modified&#xff09; DNF&#xff08;Dandified YUM&#xff09; 总结 在…...

unity学习16:unity里向量的计算,一些方法等

目录 1 unity里的向量&#xff1a; 2 向量加法 2.1 向量加法的几何意义 2.2向量加法的标量算法 3 向量减法 3.1 向量减法的几何意义 3.2 向量减法的标量算法 4 向量的标量乘法 5 向量之间的乘法要注意是左乘 还是右乘 5.1 注意区别 5.2 向量&#xff0c;矩阵&#x…...

HTML拖拽功能(纯html5+JS实现)

1、HTML拖拽--单元行拖动 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title><…...

w158医院资源管理系统的设计与实现

&#x1f64a;作者简介&#xff1a;多年一线开发工作经验&#xff0c;原创团队&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取&#xff0c;记得注明来意哦~&#x1f339;赠送计算机毕业设计600个选题excel文…...

【计算机网络】lab3 802.11 (无线网络帧)

&#x1f308; 个人主页&#xff1a;十二月的猫-CSDN博客 &#x1f525; 系列专栏&#xff1a; &#x1f3c0;计算机网络_十二月的猫的博客-CSDN博客 &#x1f4aa;&#x1f3fb; 十二月的寒冬阻挡不了春天的脚步&#xff0c;十二点的黑夜遮蔽不住黎明的曙光 目录 1. 前言 2.…...

linux进程

课本概念&#xff1a;程序的⼀个执行实例&#xff0c;正在执行的程序等内核观点&#xff1a;担当分配系统资源&#xff08;CPU时间&#xff0c;内存&#xff09;的实体。 进程信息被放在一个叫做进程控制块的数据结构中&#xff0c;可以理解为进程属性的集合.课本上称之为PCB&…...

pytest-allure框架简单封装----测试报告

安装allure-commandline---可以支持allure命令 把对应的压缩包解压后,把xxx/bin配置到环境变量的path去 可以输入allure -version检查版本 pip install allure-pytest2.11.1 生成测试报告 import pytest pytest_args ["-s","-v","--capturesys…...