web——德州扑克

news2025/1/7 20:55:52

1.此案例只用于学习

2.未接入游戏规则

   

HTML代码部分 
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<meta name="viewport" content="width=device-width">
		<meta name="Poker Skin" content="Poker Skin">
		<meta name="keywords" content="Reece, Poker, Camp">
		<title>德州扑克</title>
		<link rel="stylesheet" href="style.css">
	</head>
	<body>
		<div id="poker-wrapper" class="poker-wrapper">
			<!-- 桌面 -->
			<div class="pocker-desktop">
				<h3>Total Pot: $<span class="total-amount"></span></h3>
				<div class="poker-cards-list"></div>
			</div>
			<!-- 用户 -->
			<div class="poker-user-list"></div>
			<!-- 按钮 -->
			<div class="btn-wrapper">
				<!-- 游戏开始 -->
				<div class="btn start-game">
					开始游戏
				</div>
				<div class="btn user-call">
					玩家跟注
				</div>
				<div class="btn user-raise">
					玩家加注
				</div>
				<div class="btn user-abstention">
					玩家弃牌
				</div>
			</div>
		    <!-- 公布栏 -->
			<div class="bulletin-board-wrapper">
				<div class="bulletin-board-title">公布栏</div>
				<div class="bulletin-board-info">
					<div class="info-list">
					</div>
				</div>
			</div>
		</div>
	</body>
	<script src="index.js"></script>
</html>
CSS代码部分
/* 设置css 变量 */
/* ♠ ♥ ♣ ♦ */
:root {
	--bg-color: #676769;
	--font-color: #fff;
	--default-border-color: #fff;
	--desktop-bg-color: #151515;
	/* 花色 */
	--decor1: url("");
	--decor2: url("");
	--decor3: url("");
	--decor4: url("");
	--poker-bg-default: #c1c1c1;
	--poker-bg-color1: #2bbf29;
	--poker-bg-color2: #df4538;
	--poker-bg-color3: #3077cc;
	--poker-bg-color4: #FEC801;
	--poker-border-color: #fff;

	/* 筹码  */
	--big-blind-bg-color: #3077cc;
	--small-blind-bg-color: #ff0000;

	--info-panel-bg-color: rgba(0, 0, 0, 0.2);

	/*  按钮背景色*/
	--btn-type1: #2bbf29;
	--btn-type2: #3077cc;
	--btn-type3: #FEC801;
	--btn-type4: #df4538;
	--btn-border-color: #333;
	--btn-box-shadow: 1px 1px 5px 0px rgba(50, 50, 50, 0.75);
}


* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	font-family: Serif;
}

body {
	width: 100vw;
	height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background-color: var(--bg-color);
}

.poker-wrapper {
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
}

.poker-wrapper .pocker-desktop {
	width: 48em;
	height: 24em;
	color: var(--font-color);
	background-color: var(--desktop-bg-color);
	border-radius: 20em;
	border: 2em solid var(--desktop-border-color);
	z-index: 2;
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 1.0em;
}

.poker-wrapper .pocker-desktop .total-amount {}

/* 扑克样式 */
.poker-cards-list {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1.0em;
	position: relative;
	z-index: 10;
	color: var(--font-color);
}

.poker-cards-list .poker-card {
	padding: 0.3em;
	width: 3em;
	height: 4em;
	border: 3px solid var(--poker-border-color);
	border-radius: 5%;
	background-color: var(--poker-bg-default);
	color: var(--poker-bg-default);
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 0.2em;
}

.poker-cards-list .poker-card.active .poker-number {
	color: var(--font-color);
}

.poker-cards-list .poker-card.active .poker-decor {
	margin: auto;
	width: 2em;
	height: 2em;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: auto 100%;
}

.poker-cards-list .poker-card.active.poker-card1 {
	background-color: var(--poker-bg-color1);
}

.poker-cards-list .poker-card.active.poker-card1 .poker-decor {
	background-image: var(--decor1);
}

.poker-cards-list .poker-card.active.poker-card2 {
	background-color: var(--poker-bg-color2);
}

.poker-cards-list .poker-card.active.poker-card2 .poker-decor {
	background-image: var(--decor2);
}

.poker-cards-list .poker-card.active.poker-card3 {
	background-color: var(--poker-bg-color3);
}

.poker-cards-list .poker-card.active.poker-card3 .poker-decor {
	background-image: var(--decor3);
}

.poker-cards-list .poker-card.active.poker-card4 {
	background-color: var(--poker-bg-color4);
}

.poker-cards-list .poker-card.active.poker-card4 .poker-decor {
	background-image: var(--decor4);
}

/* 用户列表 */
.poker-user-list {
	width: 60em;
	height: 30em;
	position: absolute;
	z-index: 20;
}

.poker-user-list .poker-user-item {
	width: 10em;
	height: 5em;
	position: absolute;
	/* top: 50%;
	left: 50%; */
	transform: translateX(-50%) translateY(-50%);
}

/*弃牌样式  */
.poker-user-list .poker-user-item.abstention::before {
	display: block;
	content: "已弃牌";
	padding: .2em;
	z-index: 30;
	color: var(--font-color);
	background-color: #df4538;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
}



.poker-user-list .poker-user-item .poker-cards-list {
	gap: 0.4em;
}

.poker-user-list .poker-user-item .user-info {
	width: 10em;
	height: 3.5em;
	padding: 1em;
	color: var(--font-color);
	background-color: var(--info-panel-bg-color);
	border-radius: 0.5em;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	overflow: hidden;
	position: absolute;
	top: 50%;
	left: 0%;
	z-index: 20;
}

.poker-user-list .poker-user-item.rank .user-info::before {
	display: block;
	content: "";
	padding: 0.2em;
	border-bottom-right-radius: 0.5em;
	font-size: 12px;
	background-color: red;
	position: absolute;
	top: 0%;
	left: 0%;
}

.poker-user-list .poker-user-item.rank1 .user-info::before {
	content: "庄家";
}

.poker-user-list .poker-user-item.rank2 .user-info::before {
	content: "小盲";
}

.poker-user-list .poker-user-item.rank3 .user-info::before {
	content: "大盲";
}



.poker-user-list .poker-user-item .user-info .user-name {
	font-size: 16px;
	font-weight: bold;

}
/*用户的筹码 */

.poker-user-list .poker-user-item .user-info .user-chips{
	display: flex;
	flex-direction: row;
	justify-content: center;
	gap: 0.4em;
	position: absolute;
	right: 5%;
	bottom:15% ;
	/* transform: translateX(-50%) translateY(-50%); */
}

.poker-user-list .poker-user-item .user-info .user-chips .blind {
	width: 1em;
}

.poker-user-list .poker-user-item .user-info .user-chips .chips {
	margin-top: -1.2em;
	width: 1em;
	height: 1em;
	border-radius: 50%;
	border: 1px solid #fff;
}


.poker-user-list .poker-user-item .user-info .user-chips .big-blind .chips {
	background-color: var(--big-blind-bg-color);
}

.poker-user-list .poker-user-item .user-info .user-chips .small-blind .chips {
	background-color: var(--small-blind-bg-color);
}

/* 按钮样式 */

.btn-wrapper {
	width: fit-content;
	height: fit-content;
	display: flex;
	flex-direction: column;
	gap: 20px;
	position: absolute;
	right: 100px;
	bottom: 50%;
	transform: translateY(50%);
}


.btn-wrapper .btn {
	width: 100px;
	height: 40px;
	border: 1px solid var(--btn-border-color);
	border-radius: 4px;
	text-align: center;
	line-height: 40px;
	font-size: 16px;
	color: var(--font-color);
	cursor: pointer;
	user-select: none;
	box-shadow: var(--btn-box-shadow) transition: .2s;
}

.btn {
	transform: scale(1);
}

.btn:active {
	transform: scale(0.97);
}

/* 开始游戏 */
.btn.start-game {
	background-color: var(--btn-type1);
}

/* 跟注 */
.btn.user-call {
	background-color: var(--btn-type2);
}

/* 加注 */
.btn.user-raise {
	background-color: var(--btn-type3);
}

/* 放弃 */
.btn.user-abstention {
	background-color: var(--btn-type4);
}


/* 公布栏 */
.bulletin-board-wrapper {
	width: 20em;
	height: 17em;
	border-radius: 0.2em;
	background-color: var(--info-panel-bg-color);
	position: absolute;
	top: 2em;
	left: 2em;
}

.bulletin-board-wrapper .bulletin-board-title {
	width: 100%;
	height: 2.5em;
	font-size: 14px;
	color: var(--font-color);
	text-align: center;
	font-weight: bold;
	line-height: 2.5em;
	border-bottom: 1px solid rgba(0, 0, 0, 0.3);
}

.bulletin-board-wrapper .bulletin-board-info {
	padding: 0.5em 1em;

}

.bulletin-board-wrapper .bulletin-board-info .info-list {
	padding-right: 4px;
	width: 100%;
	height: 13.5em;
	overflow: auto;
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item {
	margin-bottom: 0.4em;
	padding: 0.4em 0.4em 0.4em 2.5em;
	width: 100%;
	border-radius: 0.2em;
	color: var(--font-color);
	background-color: #666;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	position: relative;
	overflow: hidden;
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item .info-name.rank::before {
	display: block;
	content: "";
	padding: 0.2em;
	border-bottom-right-radius: 0.5em;
	font-size: 12px;
	background-color: red;
	position: absolute;
	top: 0%;
	left: 0%;
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item .info-name.rank1::before {
	content: "庄家";
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item .info-name.rank2::before {
	content: "小盲";
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item .info-name.rank3::before {
	content: "大盲";
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item .info-total.type3 {
	color: var(--poker-bg-color3);
}

.bulletin-board-wrapper .bulletin-board-info .info-list .info-item .info-total.type4 {
	color: var(--poker-bg-color4);
}

.info-list::-webkit-scrollbar {
	width: 4px;
}

.info-list::-webkit-scrollbar-thumb {
	border-radius: 10px;
	box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
	background: rgba(0, 0, 0, 0.2);
}

.info-list::-webkit-scrollbar-track {
	box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
	border-radius: 0;
	background: rgba(0, 0, 0, 0.1);
}
JS代码部分
//扑克的点数
const pokerNumberArr = ['1', '2', '3', '4', '5', '6', '7', '8', '9', '10', 'J', 'Q', 'K']
//扑克花色 /* ♠ ♥ ♣ ♦ */
const pokerDecorArr = [1, 2, 3, 4]

// 总金额
let totalAmount = 0;
let totalAmountEl = document.querySelector(".total-amount");
//设置总金额的值
totalAmountEl.innerHTML = totalAmount

// 获取 牌桌的信息
let pokerCardsList = document.querySelector(".poker-cards-list");
const pokerNumber = 5; //桌面卡片数量
let pokerList = []; //扑克列表
addPokerCard(pokerNumber)


// 获取用户信息
let pokerUserList = document.querySelector(".poker-user-list");

//添加用户
let userList = []; //用户列表
const userNumber = 10; //人数
const angleIncrement = 360 / userNumber; // 计算角度增量
addUser(userNumber)


// 获取公示栏
let bulletinBboardInfoList = document.querySelector(".info-list");

// 开始游戏
let startGame = document.querySelector(".start-game");
//游戏开始标记
let startGameFlag = true;
// 庄家
let declarer = null;
let declarerIndex = null;
// 当前玩家
let currentUser = null;
// 当前玩家的索引
let currentUserIndex = null;
//下注执行顺序 从庄家开始进行
let userOrder = []

// 下注金额
let wagerTotal = 2
// 用户索引
let userIndex = null

// 列表索引
let userOrderIndex = 0
// 伦数
let number = 0

startGame.addEventListener("click", () => {
	if (startGameFlag) {
		startGameFlag = false;

		declarerIndex = Math.floor((Math.random() * userNumber));
		currentUserIndex = Math.floor((Math.random() * userNumber));

		// declarer = pokerUserList.children[declarerIndex];
		// declarer.classList.add("active");

		currentUser = pokerUserList.children[currentUserIndex];
		currentUser.querySelectorAll(".poker-card")[0].classList.add("active");
		currentUser.querySelectorAll(".poker-card")[1].classList.add("active");

		//重新开始游戏用户执行顺序
		userOrder = userOrder.concat(userList.splice(declarerIndex + 1)).concat(userList.splice(0,
			declarerIndex + 1));
		// 设置标记
		setMarker()
		// 从庄家用户开始检索
		startRaise(0)
	}
})

// 设置标记
function setMarker() {
	userOrder[userNumber - 1]['rank'] = 1 //庄
	userOrder[0]['rank'] = 2 //小盲
	userOrder[1]['rank'] = 3 //大盲
	pokerUserList.children[userOrder[userNumber - 1]['userIndex']].classList.add("rank", "rank1");
	pokerUserList.children[userOrder[0]['userIndex']].classList.add("rank", "rank2");
	pokerUserList.children[userOrder[1]['userIndex']].classList.add("rank", "rank3");
}


function startRaise(i) {
	for (i; i < userNumber; i++) {
		userOrderIndex = i
		let userInfo = userOrder[i]
		userIndex = userInfo.userIndex
		if (userInfo.status === 1) { //判断用户是否弃牌
			if (userIndex === currentUserIndex) { //是否是当前用户
				return
			} else { //机器人用户
				setUserTotal(i)
			}

			if (userIndex === declarerIndex) {
				userOrderIndex = 0
				number++;
				if (number === 1) {
					pokerCardsList.children[0].classList.add("active");
					pokerCardsList.children[1].classList.add("active");
					pokerCardsList.children[2].classList.add("active");
				} else if (number === 2) {
					pokerCardsList.children[3].classList.add("active");
				} else if (number === 3) {
					pokerCardsList.children[4].classList.add("active");
				} else {
					return;
				}

				startRaise(0)
				wagerTotal *= 2;
			}
		}
	}
}

// 玩家跟注
let userCall = document.querySelector(".user-call");
userCall.addEventListener("click", () => {
	if (currentUser && userIndex === currentUserIndex) {
		userOrder[userOrderIndex].wagerType = 2; //跟注
		setUserTotal(userOrderIndex)
		startRaise(userOrderIndex + 1)
	}
})

// 玩家加注
let userRaise = document.querySelector(".user-raise");
userRaise.addEventListener("click", () => {
	if (currentUser && userIndex === currentUserIndex) {
		wagerTotal *= 2;
		userOrder[userOrderIndex].wagerType = 3; //加注
		setUserTotal(userOrderIndex)
		startRaise(userOrderIndex + 1)
	}
})
// 玩家弃牌
let userAbstention = document.querySelector(".user-abstention");
userAbstention.addEventListener("click", () => {
	if (currentUser && userIndex === currentUserIndex) {
		userOrder[userOrderIndex].status = 2
		addBulletinBoardInfo(userOrder[userOrderIndex])
		pokerUserList.children[userIndex].classList.add('abstention')
		startRaise(userOrderIndex + 1)
	}
})

// 重新设置当前用户金额的信息
function setUserTotal(index) {
	userOrder[index].total = wagerTotal;
	let userTotal = pokerUserList.children[userIndex].querySelector('.user-total')
	userTotal.innerHTML = "$" + userOrder[index].total.toFixed(2)
	totalAmount += userOrder[index].total; //重新设置总金额
	totalAmountEl.innerHTML = totalAmount.toFixed(2)
	addBulletinBoardInfo(userOrder[index])
}


// 添加扑克
function addPokerCard(pokerNumber) {
	for (let i = 1; i <= pokerNumber; i++) {
		let poker = { //随机生成扑克牌信息
			"pokerNumber": pokerNumberArr[Math.floor((Math.random() * 13))],
			"pokerDecor": "poker-card" + pokerDecorArr[Math.floor((Math.random() * 4))]
		}
		pokerList.push(poker)
		let pokerCard = document.createElement("div")
		pokerCard.setAttribute("class", `poker-card ${poker.pokerDecor}`)
		pokerCard.innerHTML = setPokerInfo(poker)
		pokerCardsList.appendChild(pokerCard)
	}
}

// 设置扑克信息
function setPokerInfo(poker) {
	return `<div class="poker-number">${poker.pokerNumber}</div>
			<div class="poker-decor"></div>`
}

// 添加用户
function addUser(userNumber) {
	for (let i = 1; i <= userNumber; i++) {
		let poker1 = {
			"pokerNumber": pokerNumberArr[Math.floor((Math.random() * 13))],
			"pokerDecor": pokerDecorArr[Math.floor((Math.random() * 4))]
		}; //第一张扑克牌信息
		let poker2 = {
			"pokerNumber": pokerNumberArr[Math.floor((Math.random() * 13))],
			"pokerDecor": pokerDecorArr[Math.floor((Math.random() * 4))]
		}; //第一张扑克牌信息 //第二张扑克牌
		let pokerInfo = [poker1, poker2]; //扑克牌点数
		let userName = `用户${i}`; //用户姓名

		let total = 0; //下注金额

		totalAmount += total; //重新设置总金额
		totalAmountEl.innerHTML = totalAmount.toFixed(2)
		// 计算位置
		let angle = (i - 1) * angleIncrement; // 计算角度
		let radius = 50; // 设置半径,可以根据需要调整

		let positionTop = 50 + radius * Math.sin((angle * Math.PI) / 180);
		let positionLeft = 50 + radius * Math.cos((angle * Math.PI) / 180);

		let pokerUser = document.createElement("div")
		pokerUser.setAttribute("class", "poker-user-item")
		pokerUser.setAttribute("style", `top:${positionTop}%;left:${positionLeft}%;`)
		pokerUser.innerHTML = setUserInfo(pokerInfo, userName, total)
		pokerUserList.appendChild(pokerUser)
		userList.push({
			userId: i, //用户userId
			userIndex: (i - 1), //用户序号
			userName,
			pokerInfo,
			total,
			status: 1, //1.未弃牌 2.已弃牌
			wagerType: 1, //1.底注 2.跟注 3.加注
			rank: 0, //0.普通玩家 1.庄家 2.小盲 3.大盲
		})
	}
}

// 设置用户信息
function setUserInfo(pokerInfo, userName, total) {
	return `
	<div class="poker-cards-list">
		<div class="poker-card  poker-card${pokerInfo[0].pokerDecor}">
			<div class="poker-number">${pokerInfo[0].pokerNumber}</div>
			<div class="poker-decor"></div>
		</div>
		<div class="poker-card  poker-card${pokerInfo[1].pokerDecor}" >
			<div class="poker-number">${pokerInfo[1].pokerNumber}</div>
			<div class="poker-decor"></div>
		</div>
	</div>
	<div class="user-info">
		<div class="user-name">${userName}</div>
		<div class="user-total">$${total.toFixed(2)}</div>
		<div class="user-chips">
		<div class="blind big-blind">
				<div class="chips"></div>
				<div class="chips"></div>
				<div class="chips"></div>
				<div class="chips"></div>
			</div>
			<div class="blind small-blind">
				<div class="chips"></div>
				<div class="chips"></div>
			</div>
		</div>
	</div>`
}


// 添加 公布栏 信息
function addBulletinBoardInfo(userInfo) {
	let infoItem = document.createElement("div")
	infoItem.setAttribute("class", "info-item")
	infoItem.innerHTML = setBulletinBoardInfo(userInfo)
	bulletinBboardInfoList.appendChild(infoItem)
}

// 设置公布栏 信息
function setBulletinBoardInfo(userInfo) {
	let info = null;
	let className = ""; //类名
	let wagerType = +userInfo.wagerType //转为number类型  1.底注 2.跟注 3.加注
	let status = userInfo.status; //1.未弃牌 2.已弃牌
	let wagerTypeInfo = ["", "底注:", "跟注:", "加注:"]
	let statusInfo = ["", "未弃牌", "弃牌"]
	if (status === 1) {
		info = wagerTypeInfo[wagerType] + userInfo.total.toFixed(2);
	} else {
		info = statusInfo[status];
		wagerType = 4
	}
	className = userInfo.rank === 0 ? "" : `rank rank${userInfo.rank}`;
	return `<div class="info-name ${className}" >${userInfo.userName}</div>
			<div class="info-total type${wagerType}">${info}</div>`
}

 

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

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

相关文章

YOLOv5改进 | 注意力篇 | Deformable-LKA(DLKA)可变形的大核注意力(附多个位置添加教程)

一、本文介绍 本文给大家带来的改进内容是Deformable-LKA(可变形大核注意力)。Deformable-LKA结合了大卷积核的广阔感受野和可变形卷积的灵活性,有效地处理复杂的视觉信息。这一机制通过动态调整卷积核的形状和大小来适应不同的图像特征,提高了模型对目标形状和尺寸的适应…

转转服务瘦身实战

文章目录 1 背景2 第一步-发现并下掉僵尸服务2.1 如何发现僵尸服务2.2 如何下掉僵尸服务 3 第二步-发现并下掉僵尸方法3.1 如何发现僵尸方法3.1.1 全量方法的获取3.1.2 活动方法的获取3.1.3 ServiceAbility Agent方案详解3.1.3.1 ServiceAbility Agent使用方法3.1.3.2 解决stop…

文本批量操作技巧:告别繁琐让办公更轻松,批量添加内容的方法

在工作中&#xff0c;经常要处理大量的文本数据&#xff0c;如文档、电子表格、邮件等。如果一个个地手动编辑&#xff0c;不仅效率低下&#xff0c;还容易出错。现代办公软件提供了许多批量操作技巧&#xff0c;可以轻松完成大量文本的处理。下面一起来看下“办公提效工具”如…

计算机Java项目|基于SpringBoot+Vue的图书个性化推荐系统

项目编号&#xff1a;L-BS-GX-10 一&#xff0c;环境介绍 语言环境&#xff1a;Java: jdk1.8 数据库&#xff1a;Mysql: mysql5.7 应用服务器&#xff1a;Tomcat: tomcat8.5.31 开发工具&#xff1a;IDEA或eclipse 二&#xff0c;项目简介 图片管理系统是一个为学生和…

二叉搜索树介绍以及实现

二叉树无论是在实际运用还是面试题中&#xff0c;都是一种十分热门的数据结构&#xff0c;而二叉搜索树则是进阶版的二叉树&#xff0c;在map和set中也有应用。 什么是二叉搜索树 二叉搜索树又叫二叉排序树&#xff0c;它可以是一颗空树&#xff0c;又或者是有以下三个特点的…

编译原理笔记(三)

一、词法分析程序的设计 1、词法分析程序的输出 在识别出下一个单词同时验证其词法正确性之后&#xff0c;词法分析程序将结果以单词符号的形式发送至语法分析程序以回应其请求。 单词符号一般分下列5类&#xff1a; 关键字&#xff1a;如&#xff1a;begin、end、if、whil…

力扣2807.在链表中插入最大公约数

思路&#xff1a;遍历链表&#xff0c;对于每一个结点求出它与下一个结点的最大公约数并插入到俩个结点之间 代码&#xff1a; /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(nullptr) {}…

算法日志的存在核心在于搭建自检系统

"相信每一个人执行与日志有关的任务都会遇到这样难题吧&#xff1f;长达几万行的日志&#xff0c;如果我们单纯用肉眼去一个个排查&#xff0c;那么恐怕所耗费的时间是以天为计量单位了。当然这是一种比较夸张的情况&#xff0c;根据我的项目经验&#xff0c;正常情况是十…

【langchain】在单个文档知识源的上下文中使用langchain对GPT4All运行查询

In the previous post, Running GPT4All On a Mac Using Python langchain in a Jupyter Notebook, 我发布了一个简单的演练&#xff0c;让GPT4All使用langchain在2015年年中的16GB Macbook Pro上本地运行。在这篇文章中&#xff0c;我将提供一个简单的食谱&#xff0c;展示我们…

GeoServe本地部署结合内网穿透实现远程访问Web管理界面

文章目录 前言1.安装GeoServer2. windows 安装 cpolar3. 创建公网访问地址4. 公网访问Geo Servcer服务5. 固定公网HTTP地址 前言 GeoServer是OGC Web服务器规范的J2EE实现&#xff0c;利用GeoServer可以方便地发布地图数据&#xff0c;允许用户对要素数据进行更新、删除、插入…

STM32的在线升级(IAP)实现方法:BOOT+APP原理详解

0 工具准备 Keil uVision5 Cortex M3权威指南&#xff08;中文&#xff09; STM32参考手册 1 在线升级&#xff08;IAP&#xff09;设计思路 为了实现STM32的在线升级&#xff08;IAP&#xff09;功能&#xff0c;通常会将STM32的FLASH划分为BOOT和APP两个部分&#xff0c;BOO…

Vue组件封装

组件封装 一个封装好的组件可以在项目的任意地方使用&#xff0c;甚至我们可以直接从npm仓库下载别人封装好的组件来进行使用&#xff0c;比如iview、element-ui这一类的组件库。但是每个公司的需求是不一样的&#xff0c;我们可以封装自己的组件库并发布到npm上去&#xff0c…

【ONE·MySQL || 基本查询(CRUD)】

总言 主要内容&#xff1a;表的增删查改&#xff08;DML操作&#xff09;。insert插入&#xff08;包含插入更新、插入查询&#xff09;&#xff0c;replace替换。select查询&#xff08;包含列别名、distinct去重、where条件筛选、order排序、limit子句、group by子句、having…

【2023年度总结】多变的2023 | 成长的2023 | 蜕变的2023

文章目录 2023年&#x1f4cc;&#xff0c;对我来说2023年&#xff0c;是多变的一年&#x1f393;2023年&#xff0c;是挑战的一年&#x1f38a;2023年&#xff0c;是惊喜的一年&#x1f389;2023年&#xff0c;是好多第一次的一年&#x1f3a8; 2024年&#xff0c;是新的开始2…

计算机组成原理-进位计数制(进制表示 进制转换 真值和机器树)

文章目录 现代计算机的结构总览最古老的计数方法十进制计数法推广&#xff1a;r进制计数法任意进制->十进制二进制<--->八进制&#xff0c;十六进制 各种进制常见的书写方式十进制->任意进制整数部分小数部分 十进制->二进制&#xff08;拼凑法&#xff09;真值…

一起学docker(六)| docker网络

Docker网络 不启动docker&#xff0c;网络情况&#xff1a; 启动docker&#xff0c;网络情况&#xff1a; 作用 容器间的互联和通信以及端口映射容器IP变动时候可以通过服务名直接网络通信而不受影响 常用命令 docker network --help 查看docker网络相关命令docker network…

Elasticsearch:结合 ELSER 和 BM25 文本查询的相关搜索

Elastic Learned Spare EncodeR (ELSER) 允许你执行语义搜索以获得更相关的搜索结果。 然而&#xff0c;有时&#xff0c;将语义搜索结果与常规关键字搜索结果相结合以获得最佳结果会更有用。 问题是&#xff0c;如何结合文本和语义搜索结果&#xff1f; 首先&#xff0c;让我…

大数据 MapReduce如何让数据完成一次旅行?

专栏上一期我们聊到MapReduce编程模型将大数据计算过程切分为Map和Reduce两个阶段&#xff0c;先复习一下&#xff0c;在Map阶段为每个数据块分配一个Map计算任务&#xff0c;然后将所有map输出的Key进行合并&#xff0c;相同的Key及其对应的Value发送给同一个Reduce任务去处理…

1_开闭原则(Open Closed Principle)

开闭原则(Open Closed Principle) 1.概念 开闭原则&#xff08;Open-Closed Principle&#xff09;是指一个软件实体如类、模块和函数应该对扩展开放&#xff0c; 对修改关闭。所谓的开闭&#xff0c;也正是对扩展和修改两个行为的一个原则。强调的是用抽象构建框架&#xff…