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

DeepSeek 助力 Vue 开发:打造丝滑的瀑布流布局(Masonry Layout)

前言:哈喽,大家好,今天给大家分享一篇文章!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕

共同探索软件研发!敬请关注【宝码香车】
关注描述

csdngif标识

目录

  • DeepSeek 助力 Vue 开发:打造丝滑的瀑布流布局(Masonry Layout)
    • 📚前言
    • 📚进入安装好的DeepSeek
    • 📚页面效果
    • 📚指令输入
      • **组件属性 (Props)**
      • **组件事件 (Events)**
    • 📚think
      • 📘组件代码
        • 1. 组件实现代码
        • 2. 调用示例
        • 3. 增强建议
    • 📚代码测试
    • 📚测试代码正常跑通,附其他代码
      • 📘编写路由 src\router\index.js
      • 📘编写展示入口 src\App.vue
    • 📚页面效果
    • 📚自己部署 DeepSeek 安装地址
    • 📚相关文章


📚📗📕📘📖🕮💡📝🗂️✍️🛠️💻🚀🎉🏗️🌐🖼️🔗📊👉🔖⚠️🌟🔐⬇️·正文开始⬇️·🎥😊🎓📩😺🌈🤝🤖📜📋🔍✅🧰❓📄📢📈 🙋0️⃣1️⃣2️⃣3️⃣4️⃣5️⃣6️⃣7️⃣8️⃣9️⃣🔟🆗*️⃣#️⃣

DeepSeek 助力 Vue 开发:打造丝滑的瀑布流布局(Masonry Layout)

📚前言

对于 AI 社区来说,DeepSeek 的开源策略吸引了大量开发者和研究人员的关注和参与,形成了一个活跃的社区。开发者们可以在 GitHub 等平台上自由获取和修改模型代码,共同推动 AI 技术的发展。这种开放式的创新模式激发了更多的创意和灵感,加速了模型的更新和迭代。许多开发者基于 DeepSeek 的开源模型进行二次开发,开发出了各种有趣的应用和工具,进一步拓展了 DeepSeek 的应用场景。

在行业发展方面,DeepSeek 的开源策略降低了中小企业和个人开发者的使用成本,使得他们能够以较低的成本进行模型微调和应用开发。这有助于推动人工智能技术在各个行业的普及和应用,促进了整个 AI 行业的发展。同时,DeepSeek 与多家芯片企业合作,优化模型在国产芯片上的推理效率,推动了 AI 生态的建设。它还通过开源课程体系,培养具备全栈 AI 开发能力的复合型人才,为行业发展提供了人才支持。

📚进入安装好的DeepSeek

0基础3步部署自己的DeepSeek安装步骤

打开搭建好的DeepSeek应用。

DeepSeek应用

进入应用。

进入DeepSeek应用

📚页面效果

页面效果

📚指令输入

已经创建好了一个基于Vue3的组合式API的项目(Composition API),并能正常运行起来,请帮我用 Vue3的组合式API(Composition API) 生成一个 瀑布流布局(Masonry Layout) 的功能组件,所有代码都保存在components/MasonryLayout 下的文件夹中。功能组件的script标签中只有setup属性,使用普通 JavaScript 实现,不使用TypeScript。
功能要有,如下属性:


组件属性 (Props)

  1. columns

    • 类型: Number
    • 默认值: 2
    • 说明: 初始列数
  2. gutter

    • 类型: Number
    • 默认值: 8
    • 说明: 列间距(像素)
  3. breakpoints

    • 类型: Object
    • 默认值: {}
    • 说明: 响应式断点配置,例如 { 768: 3, 1024: 4 }
  4. resizeObserver

    • 类型: Boolean
    • 默认值: true
    • 说明: 是否监听容器尺寸变化自动重新布局
  5. useImageLoader

    • 类型: Boolean
    • 默认值: true
    • 说明: 是否监听子元素内的图片加载完成事件后重新布局
  6. itemClass

    • 类型: String
    • 默认值: 'masonry-item'
    • 说明: 子元素的 CSS 类名
  7. transitionDuration

    • 类型: Number
    • 默认值: 300
    • 说明: 布局变化时的过渡动画时长(单位:ms)

组件事件 (Events)

  1. layout-complete

    • 触发时机: 布局计算完成后
    • 参数: { columns: number, containerHeight: number }
  2. item-positioned

    • 触发时机: 单个子元素定位完成后
    • 参数: { element: HTMLElement, position: { x: number, y: number } }

你有更好的建议也可以添加,要注明。组件定义好后给出3个及以上完整的调用示例。
下面是现有目录
vueAndDeepseek/
├── src/ # 源代码目录
│ ├── assets/ # 静态资源
│ │ ├── base.css
│ │ ├── main.css
│ │ └── logo.svg
│ ├── components/ # 组件目录
│ │ ├── HelloWorld.vue
│ │ ├── TheWelcome.vue
│ │ ├── WelcomeItem.vue
│ │ ├── Progress/
│ │ │ └── Progress.vue
│ │ ├── Accordion/
│ │ ├── BackToTop/
│ │ ├── Card/
│ │ ├── InfiniteScroll/
│ │ ├── Notification/
│ │ ├── Timeline/
│ │ ├── Switch/
│ │ ├── Tabs/
│ │ ├── Sidebar/
│ │ ├── Breadcrumbs/
│ │ ├── MasonryLayout/
│ │ └── icons/
│ ├── router/ # 路由配置
│ │ └── index.js
│ ├── stores/ # Pinia 状态管理
│ │ └── counter.js
│ ├── views/ # 页面组件
│ │ ├── ProgressView.vue
│ │ ├── TabsView.vue
│ │ ├── SwitchView.vue
│ │ ├── TimelineView.vue
│ │ ├── NotificationView.vue
│ │ ├── CardView.vue
│ │ ├── InfiniteScrollView.vue
│ │ ├── BackToTopView.vue
│ │ ├── AccordionView.vue
│ │ ├── SidebarView.vue
│ │ ├── BreadcrumbsView.vue
│ │ ├── MasonryLayoutView.vue
│ │ └── AboutView.vue
│ ├── App.vue # 根组件
│ └── main.js # 应用入口
├── public/ # 公共资源目录
├── index.html # HTML 模板
├── package.json # 项目配置
├── vite.config.js # Vite 配置
└── node_modules/ # 依赖包目录

📚think

嗯,我现在需要帮用户生成一个基于Vue3组合式API的瀑布流布局组件。首先,我得理解用户的需求。他已经有一个Vue项目,使用Composition API,并且能正常运行。他想在这个基础上创建一个MasonryLayout组件,并且代码放在components/MasonryLayout文件夹下。

好的,先看看组件需要哪些属性。有columns、gutter、breakpoints这些,还有resizeObserver和useImageLoader两个布尔值。另外,还有itemClass和transitionDuration。这些都需要在setup函数中处理。

然后是事件,layout-complete和item-positioned。这两个事件要在布局完成后和每个子元素定位后触发。我需要记得使用emit来发送这些事件。

接下来,组件的结构应该是怎样的?父容器是一个div,里面包含多个子元素。子元素会根据列数排列,并且可能有图片加载的情况,所以需要用Intersection Observer来监听页面尺寸变化和图片加载完成。

在实现上,我需要计算当前屏幕宽度,根据breakpoints决定显示多少列。然后,动态设置每个子元素的位置。这涉及到测量每列的高度,将子元素放入最矮的列中。

对于响应式布局,resizeObserver为true时,应该监听页面容器大小的变化,并重新计算布局。同时,useImageLoader为true时,需要监听页面内的图片加载完成事件,调整布局。

在代码结构上,我需要用ref来管理容器和子元素,使用computed来处理当前的列数和gutter宽度。生命周期钩子mounted和unmounted用来初始化和清理观察者实例。

可能会遇到的问题是图片加载顺序不同导致布局混乱,所以需要确保所有图片都加载完成后才进行布局,或者在每个图片加载后动态调整。

测试示例部分,用户需要至少三个完整的调用示例,包括基本使用、响应式断点和复杂布局。这些示例应该展示组件的不同功能和配置选项。

最后,我得检查代码是否符合Vue3的组合式API规范,不使用TypeScript,只用普通JavaScript,并且所有逻辑都在setup函数中处理。同时,确保样式部分正确应用,包括过渡效果和边距设置。

📘组件代码

这里为您实现一个基于Vue3 Composition API的瀑布流组件,按照您的要求分文件保存:

vueAndDeepseek/
└─ src/└─ components/└─ MasonryLayout/├─ index.vue          # 组件主文件└─ MasonryLayout.vue  # 组件逻辑
1. 组件实现代码
<!-- components/MasonryLayout/index.vue -->
<template><div class="masonry-container" ref="containerRef"><slot></slot></div>
</template><script setup>
import { ref, computed, watch, onMounted, onUnmounted } from 'vue'
import { useElementSize, useWindowSize } from '@vueuse/core'const props = defineProps({columns: { type: Number, default: 2 },gutter: { type: Number, default: 8 },breakpoints: { type: Object, default: () => ({}) },resizeObserver: { type: Boolean, default: true },useImageLoader: { type: Boolean, default: true },itemClass: { type: String, default: 'masonry-item' },transitionDuration: { type: Number, default: 300 }
})const emit = defineEmits(['layout-complete', 'item-positioned'])// 响应式变量
const containerRef = ref(null)
const items = ref([])
let observer = null
let resizeObserver = null// 计算当前列数
const currentColumns = computed(() => {const { width } = useWindowSize()const breakpoints = Object.keys(props.breakpoints).map(Number).sort((a, b) => b - a)for (const bp of breakpoints) {if (width.value >= bp) {return props.breakpoints[bp]}}return props.columns
})// 核心布局方法
const calculateLayout = async () => {if (!containerRef.value) return// 等待图片加载if (props.useImageLoader) {await loadImages(containerRef.value)}const containerWidth = containerRef.value.offsetWidthconst colWidth = (containerWidth - (currentColumns.value - 1) * props.gutter) / currentColumns.valueconst positions = Array(currentColumns.value).fill(0)items.value = Array.from(containerRef.value.children).filter(el => el.classList.contains(props.itemClass))items.value.forEach(item => {const minHeight = Math.min(...positions)const columnIndex = positions.indexOf(minHeight)const x = columnIndex * (colWidth + props.gutter)const y = minHeight// 应用定位item.style.transform = `translate(${x}px, ${y}px)`item.style.transition = `transform ${props.transitionDuration}ms`// 触发单个元素定位事件emit('item-positioned', {element: item,position: { x, y }})positions[columnIndex] += item.offsetHeight + props.gutter})// 更新容器高度containerRef.value.style.height = `${Math.max(...positions)}px`emit('layout-complete', {columns: currentColumns.value,containerHeight: Math.max(...positions)})
}// 图片加载处理
const loadImages = (container) => {return Promise.all(Array.from(container.querySelectorAll('img')).map(img => {if (img.complete) return Promise.resolve()return new Promise(resolve => {img.onload = resolveimg.onerror = resolve})}))
}// 监听器设置
const setupObservers = () => {if (props.resizeObserver && containerRef.value) {resizeObserver = new ResizeObserver(calculateLayout)resizeObserver.observe(containerRef.value)}if (window.MutationObserver) {observer = new MutationObserver(calculateLayout)observer.observe(containerRef.value, {childList: true,subtree: true})}
}// 生命周期
onMounted(() => {calculateLayout()setupObservers()window.addEventListener('resize', calculateLayout)
})onUnmounted(() => {if (resizeObserver) resizeObserver.disconnect()if (observer) observer.disconnect()window.removeEventListener('resize', calculateLayout)
})// 响应props变化
watch([currentColumns, () => props.gutter], calculateLayout)
</script><style scoped>
.masonry-container {position: relative;margin: 0 auto;
}.masonry-container :deep(.masonry-item) {position: absolute;box-sizing: border-box;will-change: transform;
}
</style>
2. 调用示例
<!-- views/MasonryLayoutView.vue -->
<template><!-- 基础示例 --><MasonryLayout:columns="2":gutter="10"@layout-complete="handleLayoutComplete"><div v-for="(item, index) in 20" :key="index"class="masonry-item":style="{ height: `${Math.random() * 300 + 100}px`, background: randomColor() }"/></MasonryLayout><!-- 响应式断点示例 --><MasonryLayout:columns="2":breakpoints="{ 768: 3, 1024: 4 }":gutter="15":transition-duration="500"><div v-for="(item, index) in images" :key="item.id"class="masonry-item"><img :src="item.url" alt=""></div></MasonryLayout><!-- 动态内容示例 --><button @click="addItems">添加元素</button><MasonryLayoutref="masonry":item-class="customItemClass":resize-observer="false"><div v-for="(item, index) in dynamicItems" :key="index":class="customItemClass":style="{ height: item.height }"/></MasonryLayout>
</template><script setup>
import { ref } from 'vue'// 示例数据
const randomColor = () => '#' + Math.floor(Math.random()*16777215).toString(16)const images = ref([{ id: 1, url: '/image1.jpg' },{ id: 2, url: '/image2.jpg' },// ...
])const dynamicItems = ref(Array(10).fill().map(() => ({height: `${Math.random() * 400 + 100}px`,color: randomColor()
})))const customItemClass = 'custom-masonry-item'const handleLayoutComplete = ({ columns, containerHeight }) => {console.log(`布局完成,列数:${columns},容器高度:${containerHeight}px`)
}const addItems = () => {dynamicItems.value.push({height: `${Math.random() * 400 + 100}px`,color: randomColor()})// 手动触发布局更新nextTick(() => {masonry.value.calculateLayout()})
}
</script><style>
.custom-masonry-item {width: 100%;background: #f0f0f0;border-radius: 8px;padding: 1rem;transition: transform 0.5s ease-in-out;
}
</style>
3. 增强建议
  1. 性能优化

    • 添加虚拟滚动支持(对于大数据量)
    • 使用requestAnimationFrame优化布局计算
    • 添加布局缓存机制
  2. 功能扩展

    // 在组件中暴露方法
    defineExpose({calculateLayout,refreshLayout: calculateLayout
    })
    
  3. 错误处理

    // 在图片加载处添加错误处理
    const loadImages = (container) => {return Promise.all(Array.from(container.querySelectorAll('img')).map(img => {return new Promise(resolve => {if (img.complete) return resolve()img.onload = resolveimg.onerror = resolve // 即使图片加载失败也继续执行})}))
    }
    
  4. SSR支持

    // 在onMounted中初始化观察器
    if (typeof window !== 'undefined') {// 初始化代码
    }
    

这个实现包含了您要求的所有功能,并通过三个示例展示了不同的使用场景。组件会自动响应窗口大小变化、内容变化和图片加载,并提供了良好的可扩展性。

📚代码测试

正常

📚测试代码正常跑通,附其他代码

  • 添加路由
  • 页面展示入口

📘编写路由 src\router\index.js

\router\index.js

import { createRouter, createWebHistory } from 'vue-router'const router = createRouter({history: createWebHistory(import.meta.env.BASE_URL),routes: [{path: '/',name: 'progress',component:  () => import('../views/ProgressView.vue'),},{path: '/tabs',name: 'tabs',// route level code-splitting// this generates a separate chunk (About.[hash].js) for this route// which is lazy-loaded when the route is visited.// 标签页(Tabs)component: () => import('../views/TabsView.vue'),},{path: '/accordion',name: 'accordion',// 折叠面板(Accordion)component: () => import('../views/AccordionView.vue'),},{path: '/timeline',name: 'timeline',// 时间线(Timeline)component: () => import('../views/TimelineView.vue'),},{path: '/backToTop',name: 'backToTop',component: () => import('../views/BackToTopView.vue')},{path: '/notification',name: 'notification',component: () => import('../views/NotificationView.vue')},{path: '/card',name: 'card',component: () => import('../views/CardView.vue')},{path: '/infiniteScroll',name: 'infiniteScroll',component: () => import('../views/InfiniteScrollView.vue')},{path: '/switch',name: 'switch',component: () => import('../views/SwitchView.vue')},{path: '/sidebar',name: 'sidebar',component: () => import('../views/SidebarView.vue')},{path: '/breadcrumbs',name: 'breadcrumbs',component: () => import('../views/BreadcrumbsView.vue')},{path: '/masonryLayout',name: 'masonryLayout',component: () => import('../views/masonryLayoutView.vue')}],
})export default router

📘编写展示入口 src\App.vue

 src\App.vue

<script setup>
import { RouterLink, RouterView } from 'vue-router'
import HelloWorld from './components/HelloWorld.vue'
</script><template><header><img alt="Vue logo" class="logo" src="@/assets/logo.svg" width="125" height="125" /><div class="wrapper"><HelloWorld msg="You did it!" /><nav><RouterLink to="/">Progress</RouterLink><RouterLink to="/tabs">Tabs</RouterLink><RouterLink to="/accordion">Accordion</RouterLink><RouterLink to="/timeline">Timeline</RouterLink><RouterLink to="/backToTop">BackToTop</RouterLink><RouterLink to="/notification">Notification</RouterLink><RouterLink to="/card">Card</RouterLink><RouterLink to="/infiniteScroll">InfiniteScroll</RouterLink><RouterLink to="/switch">Switch</RouterLink><RouterLink to="/sidebar">Sidebar</RouterLink><RouterLink to="/breadcrumbs">Breadcrumbs</RouterLink><RouterLink to="/masonryLayout">MasonryLayout</RouterLink></nav></div></header><RouterView />
</template><style scoped>
header {line-height: 1.5;max-height: 100vh;
}.logo {display: block;margin: 0 auto 2rem;
}nav {width: 100%;font-size: 12px;text-align: center;margin-top: 2rem;
}nav a.router-link-exact-active {color: var(--color-text);
}nav a.router-link-exact-active:hover {background-color: transparent;
}nav a {display: inline-block;padding: 0 1rem;border-left: 1px solid var(--color-border);
}nav a:first-of-type {border: 0;
}@media (min-width: 1024px) {header {display: flex;place-items: center;padding-right: calc(var(--section-gap) / 2);}.logo {margin: 0 2rem 0 0;}header .wrapper {display: flex;place-items: flex-start;flex-wrap: wrap;}nav {text-align: left;margin-left: -1rem;font-size: 1rem;padding: 1rem 0;margin-top: 1rem;}
}
</style>

📚页面效果

页面效果

📚自己部署 DeepSeek 安装地址

蓝耘元生代智算云平台地址:https://cloud.lanyun.net/#/registerPage?promoterCode=07100c37a0

📚相关文章

 

———— 相 关 文 章 ————

 

  1. 0基础3步部署自己的DeepSeek安装步骤

  2. DeepSeek 助力 Vue 开发:打造丝滑的步骤条(Step bar)

  3. DeepSeek 助力 Vue 开发:打造丝滑的进度条(Progress Bar)

  4. 自己部署 DeepSeek 助力 Vue 开发:打造丝滑的标签页(Tabs)

  5. 自己部署 DeepSeek 助力 Vue 开发:打造丝滑的折叠面板(Accordion)

  6. 自己部署 DeepSeek 助力 Vue 开发:打造丝滑的时间线(Timeline )

  7. DeepSeek 助力 Vue 开发:打造丝滑的返回顶部按钮(Back to Top)

  8. DeepSeek 助力 Vue 开发:打造丝滑的通知栏(Notification Bar)

  9. DeepSeek 助力 Vue 开发:打造丝滑的卡片(Card)

  10. DeepSeek 助力 Vue 开发:打造丝滑的无限滚动(Infinite Scroll)

  11. DeepSeek 助力 Vue 开发:打造丝滑的开关切换(Switch)

  12. DeepSeek 助力 Vue 开发:打造丝滑的侧边栏(Sidebar)

  13. DeepSeek 助力 Vue 开发:打造丝滑的面包屑导航(Breadcrumbs)

到此这篇文章就介绍到这了,更多精彩内容请关注本人以前的文章或继续浏览下面的文章,创作不易,如果能帮助到大家,希望大家多多支持宝码香车~💕,若转载本文,一定注明本文链接。


整理不易,点赞关注宝码香车

更多专栏订阅推荐:
👍 html+css+js 绚丽效果
💕 vue
✈️ Electron
⭐️ js
📝 字符串
✍️ 时间对象(Date())操作

相关文章:

DeepSeek 助力 Vue 开发:打造丝滑的瀑布流布局(Masonry Layout)

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;今天给大家分享一篇文章&#xff01;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01;创作不易&#xff0c;如果能帮助到大家或者给大家一些灵感和启发&#xff0c;欢迎收藏关注哦 &#x1f495; 目录 Deep…...

C++:从拷贝构造函数到深浅拷贝

拷贝构造函数 当实例化一个新对象并使用同类型对其进行初始化时&#xff0c;会显式调用类的拷贝构造函数&#xff0c;拷贝构造函数写法&#xff1a;形参为const修饰的同类型类引用。拷贝构造函数有个需要注意的点&#xff0c;形参为何是只允许传递引用呢&#xff1f;原因在于若…...

Openssl之SM2加解密命令

### 1. 生成 SM2 私钥openssl genpkey -algorithm EC \-pkeyopt ec_paramgen_curve:sm2 \-out sm2_private_key.pem### 2. 从私钥导出 SM2 公钥openssl pkey -in sm2_private_key.pem \-pubout \-out sm2_public_key.pem### 3. 使用 SM2 公钥加密openssl pkeyutl -encrypt \-pu…...

Java集合框架之List接口详解

目录 一、List接口概述 二、List接口常见实现类 三、List接口特有方法: 1.元素操作 2. 查找元素位置 3. 子列表与不可变列表 四、List特有迭代器:ListIterator 1.特有的迭代方式 2.ListIterator接口中的常用方法: ⑴.void add(E e):在光标位置插入元素。(会移动…...

oracle apex post接口

日常记录 使用到了apex_json方式接收 、、、1 首先&#xff0c;接口通过body传递过来&#xff0c;成功接收到&#xff0c; 数据格式为 JSON_OBJECT_T l_json : JSON_OBJECT_T.parse(:body); 这里我用参数接收到 然后 里面是包含了 "data" 我用 继续接收到这个 l…...

【数据挖掘】--算法

【数据挖掘】--算法 目录&#xff1a;1. 缺失值和数值属性处理1缺失值处理&#xff1a; 2. 用于文档分类的朴素贝叶斯3. 分治法&#xff1a;建立决策树4. 覆盖算法建立规则5. 挖掘关联规则6. 线性模型有效寻找最近邻暴力搜索&#xff08;Brute-Force Search&#xff09;kd树&am…...

halcon机器视觉深度学习对象检测,物体检测

目录 效果图操作步骤软件版本halcon参考代码本地函数 get_distinct_colors()本地函数 make_neighboring_colors_distinguishable() 效果图 操作步骤 首先要在Deep Learning Tool工具里面把图片打上标注文本&#xff0c; 然后训练模型&#xff0c;导出模型文件 这个是模型 mod…...

英文字体:极简现代浓缩未来派科技海报标题排版无衬线字体 PODIUM Sharp Font

PODIUM Sharp 是 2012 年设计的 DUDU 字体的扩展版本。多年后&#xff0c;我决定通过添加新的母版和粗细来重建和开发这种字体。最后&#xff0c;PODIUM Sharp 由 234 种款式组成&#xff1a;从超压缩发际线到超扩展重度。 这个项目的主要目的是在我在旧波兰标本中发现的不同模…...

Java中JDK、JRE,JVM之间的关系

Java中的JDK、JRE和JVM是三个核心概念&#xff0c;其关系可概括为JDK > JRE > JVM&#xff0c;具体如下&#xff1a; 一、定义与作用 JDK&#xff08;Java Development Kit&#xff09; 定义&#xff1a;Java开发工具包&#xff0c;用于开发和编译Java程序。包含内容&…...

elasticsearch在windows上的配置

写在最前面&#xff1a; 上资源 第一步 解压&#xff1a; 第二步 配置两个环境变量 第三步 如果是其他资源需要将标蓝的文件中的内容加一句 xpack.security.enabled: false 不同版本的yaml文件可能配置不同&#xff0c;末尾加这个 xpack.security.enabled: true打开bin目…...

vscode 配置 Copilot 提示GHE.com连接失败

步骤一&#xff1a;打开设置并进入 settings.json 点击菜单栏中的 “文件” -> “首选项” -> “设置”。 在搜索设置栏中输入 “Copilot: Advanced”。 点击搜索结果下方的 “在 settings.json 中编辑” 链接&#xff0c;这会打开 settings.json 文件。 步骤二&#…...

Pycharm+CodeGPT+Ollama+Deepseek

首先&#xff0c;体验截图&#xff1a; 接着&#xff1a; 1、下载Ollama&#xff1a; Download Ollama on macOS 2、下载模型 以1.5b为例&#xff0c;打开命令行&#xff0c;输入: ollama run deepseek-r1:1.5b 3、Pycharm安装Code GPT插件 打开PyCharm&#xff0c;找到文…...

Unreal5从入门到精通之在编辑器中更新 UserWidgets

前言 在虚幻中创建越来越复杂和灵活的 UserWidget 蓝图时,一个问题是它们在编辑器中的外观与它们在游戏中的最终外观可能有很大不同。 库存面板示例 假设你想创建一个通用的库存显示小部件。我们可以在整个 UI 中使用它,无论我们需要在哪里显示某些内容。 标题,描述所显示…...

C语言修炼手册

目录 第一章 分支与循环语句 1. 悬空else问题 2. 循环输入问题 3. getchar缓冲区溢出问题 4. goto语句坑点 第二章 函数 1.为什么要有库函数 2.函数嵌套 3.链式访问 4.回调函数 5.函数递归 6.字符转换函数 7.模拟实现字符串拷贝strcpy 8.模拟实现字符串的长度s…...

Linux部署ollama

1、下载ollama wget https://github.com/ollama/ollama/releases/download/v0.1.47/ollama-linux-amd64或者curl -fsSL https://ollama.com/install.sh | sh2、安装ollama install ollama-linux-amd64 /usr/local/bin/ollama3、启动ollama vi /etc/systemd/system/ollama.se…...

跨语言语义理解与生成:多语言预训练方法及一致性优化策略

网罗开发 &#xff08;小红书、快手、视频号同名&#xff09; 大家好&#xff0c;我是 展菲&#xff0c;目前在上市企业从事人工智能项目研发管理工作&#xff0c;平时热衷于分享各种编程领域的软硬技能知识以及前沿技术&#xff0c;包括iOS、前端、Harmony OS、Java、Python等…...

最新华为 HCIP-Datacom(H12-821)2025.2.20

最新 HCIP-Datacom&#xff08;H12-821&#xff09;&#xff0c;完整题库请扫描上方二维码访问。 如图所示为某OSPF网络&#xff0c;已知R1和R2已,成功建立邻接关系&#xff0c;现一工程师在R2上配置了图中命令。那么在R2上查看LSDB时&#xff0c;可能存在以下哪些LSA? A&…...

TS语言自定义脚手架

初始化 新建文件夹初始化命令 npm init -ytsc --initnpm i types/nodenpm i typescript# 处理别名npm i -D tsc-alias -y 表示选项都为yes 安装ts相关依赖 新建相关文件 bin 文件夹 src文件夹 commands 文件夹 &#xff08;命令 utils 文件夹 (封装方法&#xff09; index.t…...

深度学习-122-大语言模型LLM之基于langchian自定义国内联网查询工具并创建智能代理

文章目录 1 访问百度1.1 百度检索1.2 库baidusearch2 自定义工具@tool装饰器3 使用工具创建智能代理3.1 语言模型与工具结合3.2 方式一create_react_agent3.3 方式二create_tool_calling_agent3.4 给代理添加记忆4 参考附录1 访问百度 1.1 百度检索 from bs4 import Beautifu…...

Docker Desktop 入门教学

引言 Docker Desktop 是 Docker 官方为开发者提供的桌面应用程序&#xff0c;支持在 Windows 和 macOS 上轻松构建、运行和共享容器化应用程序。它集成了 Docker 引擎、Docker CLI 客户端以及 Docker Compose 等工具&#xff0c;方便您在本地开发和测试。 一、快速安装 1. 系…...

设计模式和设计原则回顾

设计模式和设计原则回顾 23种设计模式是设计原则的完美体现,设计原则设计原则是设计模式的理论基石, 设计模式 在经典的设计模式分类中(如《设计模式:可复用面向对象软件的基础》一书中),总共有23种设计模式,分为三大类: 一、创建型模式(5种) 1. 单例模式(Sing…...

CMake 从 GitHub 下载第三方库并使用

有时我们希望直接使用 GitHub 上的开源库,而不想手动下载、编译和安装。 可以利用 CMake 提供的 FetchContent 模块来实现自动下载、构建和链接第三方库。 FetchContent 命令官方文档✅ 示例代码 我们将以 fmt 这个流行的格式化库为例,演示如何: 使用 FetchContent 从 GitH…...

自然语言处理——循环神经网络

自然语言处理——循环神经网络 循环神经网络应用到基于机器学习的自然语言处理任务序列到类别同步的序列到序列模式异步的序列到序列模式 参数学习和长程依赖问题基于门控的循环神经网络门控循环单元&#xff08;GRU&#xff09;长短期记忆神经网络&#xff08;LSTM&#xff09…...

Java多线程实现之Thread类深度解析

Java多线程实现之Thread类深度解析 一、多线程基础概念1.1 什么是线程1.2 多线程的优势1.3 Java多线程模型 二、Thread类的基本结构与构造函数2.1 Thread类的继承关系2.2 构造函数 三、创建和启动线程3.1 继承Thread类创建线程3.2 实现Runnable接口创建线程 四、Thread类的核心…...

Unsafe Fileupload篇补充-木马的详细教程与木马分享(中国蚁剑方式)

在之前的皮卡丘靶场第九期Unsafe Fileupload篇中我们学习了木马的原理并且学了一个简单的木马文件 本期内容是为了更好的为大家解释木马&#xff08;服务器方面的&#xff09;的原理&#xff0c;连接&#xff0c;以及各种木马及连接工具的分享 文件木马&#xff1a;https://w…...

Aspose.PDF 限制绕过方案:Java 字节码技术实战分享(仅供学习)

Aspose.PDF 限制绕过方案&#xff1a;Java 字节码技术实战分享&#xff08;仅供学习&#xff09; 一、Aspose.PDF 简介二、说明&#xff08;⚠️仅供学习与研究使用&#xff09;三、技术流程总览四、准备工作1. 下载 Jar 包2. Maven 项目依赖配置 五、字节码修改实现代码&#…...

Linux离线(zip方式)安装docker

目录 基础信息操作系统信息docker信息 安装实例安装步骤示例 遇到的问题问题1&#xff1a;修改默认工作路径启动失败问题2 找不到对应组 基础信息 操作系统信息 OS版本&#xff1a;CentOS 7 64位 内核版本&#xff1a;3.10.0 相关命令&#xff1a; uname -rcat /etc/os-rele…...

浪潮交换机配置track检测实现高速公路收费网络主备切换NQA

浪潮交换机track配置 项目背景高速网络拓扑网络情况分析通信线路收费网络路由 收费汇聚交换机相应配置收费汇聚track配置 项目背景 在实施省内一条高速公路时遇到的需求&#xff0c;本次涉及的主要是收费汇聚交换机的配置&#xff0c;浪潮网络设备在高速项目很少&#xff0c;通…...

Golang——7、包与接口详解

包与接口详解 1、Golang包详解1.1、Golang中包的定义和介绍1.2、Golang包管理工具go mod1.3、Golang中自定义包1.4、Golang中使用第三包1.5、init函数 2、接口详解2.1、接口的定义2.2、空接口2.3、类型断言2.4、结构体值接收者和指针接收者实现接口的区别2.5、一个结构体实现多…...

uniapp 小程序 学习(一)

利用Hbuilder 创建项目 运行到内置浏览器看效果 下载微信小程序 安装到Hbuilder 下载地址 &#xff1a;开发者工具默认安装 设置服务端口号 在Hbuilder中设置微信小程序 配置 找到运行设置&#xff0c;将微信开发者工具放入到Hbuilder中&#xff0c; 打开后出现 如下 bug 解…...