实战案例:初探工程配置 图标组件热身

news2025/1/24 11:37:35

点击上方卡片“前端司南”关注我

您的关注意义重大

3004e6fde3282eddf8c6ef135b57bd4f.jpeg

原创@前端司南

前言

本文是 基于Vite+AntDesignVue打造业务组件库[1] 专栏第 3 篇文章【实战案例:初探工程配置 & 图标组件热身】,我将从业务系统中最基础的图标组件入手,带着读者们练练手找找感觉,快速进入开发状态,顺便了解一些基本的前端工程配置。

引入Formatter/Linter工具

在正式地开发组件之前,我们需要一点点准备工作。

为了提高开发效率,避免低级错误,我们有必要先引入一些工具,毫无疑问,ESLint, Prettier, StyleLint 可以先安排上,相关配置点到为止,不会一来就堆大量的配置

首先我们把 VSCode 的相关插件安装好。

5fa24403652c4ba5eb858d344e0f96a1.png 20a326353a862105af92abd19a86976e.png 411302f377e2778c1970820e3bd097c7.png

由于我们用的是 Vue3 开发组件库,Volar 也可以直接安装上!

c28ba492c4a365b8ce149e1230346ad0.png

我们还将这些插件加到了.vscode/extensions.json中,这样别人打开这个项目时,VSCode 就会自动推荐 ta 安装相关的插件。

a4ac2fb34fa5de30076ca9f3ca55fc51.png

ESLint

然后我们从 ESLint[2] 开始配置环境。

59adf9a1f61c445836b23a879728880a.png

打开官网,可以看到官方已经给我们提供了相关命令,我们执行npm init @eslint/config初始化一下。

87ac14f79394c69cae96d42846dfd4ae.png

会发现安装依赖过程中 Yarn 给我们抛了一个错误。在 workspaces 特性启用时,Yarn 默认认为我们执行yarn add时是希望将依赖安装到某个 workspace 下面而不是工程的根目录下。而这里,我们需要将 eslint 的这些依赖安装到工程的根目录下,可以加上-W参数手动安装一下依赖,这些依赖在上面的日志信息中可以找到。

yarn add -DW eslint-plugin-vue@latest eslint-config-standard-with-typescript@latest @typescript-eslint/eslint-plugin@^5.0.0 eslint@^8.0.1 eslint-plugin-import@^2.25.2 eslint-plugin-n@^15.0.0 eslint-plugin-promise@^6.0.0 typescript@*

此时可以发现 eslint 已经在报一些错误了。

abc345c552caf3aca7baf82749492d48.png

而对于 indent,我习惯用 4 个 space,这里自定义一下 rule。

"rules": {
    "indent": ["warn", 4]
}

改完之后,indent 相关的报错信息消失了,而其他的错误依旧在,此时,还只能通过右键菜单来进行 Format,不是特别方便。

ff6f38435702c1e8b542bbbd1e777f14.png

为了方便使用和自动修复一些代码质量问题,我们把 VSCode 和 ESLint 的 Fix 能力结合一下。我们新增一个.vsocde/settings.json,配置如下:

{
    "editor.tabSize": 4,
    "eslint.validate": ["javascript", "typescript", "javascriptreact", "typescriptreact", "vue"],
    // 防止内置css校验和stylelint重复报错
    "css.validate": false,
    "less.validate": false,
    "scss.validate": false,
    "editor.formatOnSave": false,
    // 代码保存动作
    "editor.codeActionsOnSave": {
        "source.fixAll.eslint": true,
        "source.fixAll.stylelint": true
    },
    "editor.defaultFormatter": "esbenp.prettier-vscode",
    "[vue]": {
        "editor.defaultFormatter": "Vue.volar"
    },
    "typescript.tsdk": "node_modules/typescript/lib"
}

接着验证一下是不是生效了,从下图中可以看到,保存代码可以自动 format 了。

e98cf42022b5d739b6461fc2e24773e1.gif

基本的路子摸清后,我们可以完善一下 JavaScript 的编码风格规范了,闭着眼睛推荐eslint-config-airbnb-base,具体规范可以参考airbnb/javascript(请自行上github找一下),阅读一遍有助于培养良好的编码意识。

yarn add -DW eslint-config-airbnb-base eslint-plugin-import

eslint 关键配置:

extends: [
    'eslint:recommended',
    'plugin:import/recommended',
    'airbnb-base'
],
plugins: ['import'],

It requires eslint and eslint-plugin-import.

eslint-plugin-import 是 eslint-config-airbnb-base 要求安装的,同时也是开发过程中的一个利器,保证我们能按预期使用 ES 的模块 import/export。

StyleLint

接着我们把负责样式风格和质量的 StyleLint[3] 也配置一下,这里顺手安装了几个 config,包括 StyleLint 的标准配置以及应用到 SCSS-like 文件 和 Vue 文件的特有配置。

yarn add -DW stylelint stylelint-config-standard stylelint-config-standard-scss stylelint-config-standard-vue postcss-html

postcss-html 是与 stylelint-config-standard-vue 配合使用的。

初始配置文件可以简单引入上面那几个 config。

module.exports = {
    extends: [
        'stylelint-config-standard',
        'stylelint-config-standard-scss',
        'stylelint-config-standard-vue/scss'
    ],
    rules: {
        indentation: 4
    }
}

为了与 VSCode 更好地集成,我们修改一下.vscode/settings.json,加入以下配置:

"stylelint.validate": [
    "css",
    "less",
    "vue"
]

此时我们随意修改一下样式,测试一下效果,可以看到基本的提示和修复能力都有了。

478b6edff828f0bce7fa889dc0cf17dd.gif

Prettier

项目中要不要使用 Prettier 取决于个人,没有强制的要求,毕竟没有 Prettier 之前,大家也活得挺好。做这个决定前要搞清楚 Prettier 和 ESLint / StyleLint 这类 Linter 扮演的角色分别是什么。简单说就是 Prettier 负责代码风格,而 Linter 负责代码质量

引用官方文档的一句话:Prettier for formatting and linters for catching bugs!

读过 Prettier 的这篇文档[4]你就可以知道,Prettier 和 Linters 会有一些功能交叉和规则冲突。功能交叉指的是 Linter 除了负责代码质量外,本身也可以定义规则约束代码风格,这就有可能会与 Prettier 的代码风格产生冲突。这个时候,就需要通过 Linter 体系中的一些插件配置关掉一部分与 Prettier 有冲突的规则,尽量在风格上以 Prettier 为准,比如 eslint-config-prettier[5] 和 stylelint-config-prettier[6]

我们安装一下 Prettier 和相关配套试试:

yarn add -DW prettier eslint-config-prettier stylelint-config-prettier

新建一个prettier.config.js配置文件,写入一些简单的配置:

module.exports = {
    tabs: false,
    tabWidth: 4,
    endOfLine: 'auto',
    semi: false,
    singleQuote: true
}

接着把eslint-config-prettierstylelint-config-prettier配置好。

// eslint 配置
extends: [
    // 引入 eslint-config-prettier
    'prettier'
],
// stylelint 配置
extends: [
    // 引入 stylelint-config-prettier
    'stylelint-config-prettier'
],

此时,我们会发现随意修改 vue 文件后,对于一些低级的代码风格问题,VSCode 提示都没有了。

707385e80c09792ed4001e1517b42299.png

我去,这都不报错!看来是eslint-config-prettier把有冲突的 rules 关得很彻底!好,这个时候我们需要把 Prettier 的输出反馈给 ESLint,让 ESLint 来做提示,这需要用到 eslint-plugin-prettier[7]

Runs Prettier[8] as an ESLint[9] rule and reports differences as individual ESLint issues.

先安装一下依赖,

yarn add -DW eslint-plugin-prettier

然后把下面的 ESLint 配置做好,这相当于把 Prettier 作为 ESLint 检查工序中的一个环节了。

// .eslintrc.js
{
  "plugins": ["prettier"],
  "rules": {
    "prettier/prettier": "error"
  }
}

4b87c05e6f4eabbd5238a163d66cd1b6.gif

哥们儿,这感觉嘎嘎上来了,要的就是这个效果,看来这就是 Prettier 接管了 ESLint 一部分工作的精髓啊!

类似地,我们把stylelint-prettier也安装一下。

yarn add -DW stylelint-prettier

修改配置:

// stylelint.config.js
{
  "plugins": ["stylelint-prettier"],
  "rules": {
    "prettier/prettier": true
  }
}

TypeScript

我们尝试把一些原有的 js 文件改成 ts,会发现 ESLint 先报了一个错,这是因为 ESLint 的内置 parser Espree[10] 不能处理 ts 文件,我们需要引入新的 parser。

4e89febed808bb3e3e1da89063d973f6.png

对于 ESLint 和 TypeScript 的结合,我们主要关注这个仓库 typescript-eslint[11],这里面有我们需要的 @typescript-eslint/parser@typescript-eslint/eslint-plugin

我们先安装一下这些依赖:

yarn add -DW typescript @typescript-eslint/parser @typescript-eslint/eslint-plugin

新建一个tsconfig.json,基本内容如下:

{
    "compilerOptions": {
        "target": "esnext",
        "module": "esnext",
        "strict": false,
        "jsx": "preserve",
        "importHelpers": true,
        "moduleResolution": "node",
        "baseUrl": "./",
        "rootDir": ".",
        "skipLibCheck": true,
        "esModuleInterop": true,
        "allowSyntheticDefaultImports": true,
        "sourceMap": true,
        "resolveJsonModule": true,
        "allowJs": true,
        "strictNullChecks": true,
        "lib": ["esnext", "dom", "dom.iterable", "scripthost"]
    },
    "include": ["**/*.ts", "**/*.tsx", "**/*.vue", "**/tests/**/*.ts", "**/tests/**/*.tsx", "**/components.d.ts"],
    "exclude": ["node_modules"]
}

接着在.eslintrc.js中把 @typescript-eslint/parser@typescript-eslint/eslint-plugin 及相关配置处理好。

70601f047e625601ad97d2f9fdc09d0c.png

一切都比较符合预期,但是当我们打开一个.vue文件时,会发现有报错信息:

Parsing error: "parserOptions.project" has been set for @typescript-eslint/parser. The file does not match your project config: packages\vue-pro-components\src\icon\icon.vue. The extension for the file (.vue) is non-standard. You should add "parserOptions.extraFileExtensions" to your config.

accfa8672cba44a8a6a174424699f7e9.png

我的第一反应是认为我们配置的@typescript-eslint/parser无法识别.vue文件,这时候就需要用到vue-eslint-parser了。

然而引入vue-eslint-parser并把基本配置做好后,这个报错依然没有消失。想着关机一次试试,没有用。等了两天再打开,又不报错了,没想明白。不过vue-eslint-parser肯定是少不了的。

f177404c8a7ad833ffc0ef71a5b92c22.png

TypeScript 在配合eslint-plugin-import使用时,我们还需要配置一下eslint-import-resolver-typescript[12],这个在相关插件的文档中也有提到。否则会报这些错误:

4bf5ba20af1de5eee5af638d203b6922.png
yarn add -DW eslint-import-resolver-typescript

补充的关键配置如下:

// .eslintrc.js
extends: [
    // ...
    'plugin:import/typescript',
],
settings: {
    // ...
    'import/resolver': {
        typescript: {
            alwaysTryTypes: true, // always try to resolve types under `<root>@types` directory even it doesn't contain any source code, like `@types/unist`
            // Multiple tsconfigs (Useful for monorepos)
            // use an array of glob patterns
            project: ['tsconfig.json', 'packages/*/tsconfig.json'],
        },
    },
},

less

我们测试一下能不能正常使用 less 开发,先把icon.vuestyle blocklang设置为less试试。

4bc5409cac045919cb7d5d18818bc880.png

由于 package vue-pro-components中的文件都改成 ts 了,其中也包括入口文件index.ts,所以我们还需要把package.jsonmain入口修改成index.ts,才能顺利调试。

9acb22f20a73566eadcb11bcff7db59e.png

但是把 dev 环境跑起来后,还是报了 less 相关的错误。

40f2641a7dbdb6e94a9dab0495edc958.png

由于 dev 环境是 package playground的,只是它引用了 package vue-pro-components中的Icon组件,所以是 package playground的环境中缺失less,我们给它安装一下less依赖。

lerna add less --scope=playground --dev

图标组件需求

基本的环境准备好之后,我们来实现一个简单的 Icon 组件热热身。

虽然 UI 组件库都标配了 Icon 组件,但是这些图标通常来说是不够用的,很难满足不同项目的需求,所以有必要自己实现一个 Icon 组件,能够方便地管理和使用图标。

前端与 UI 设计师通常利用 iconfont 来进行图标协作,图标的表现形式有字体图标,SVG 图标等,我们就先从字体图标开始。

准备一个 iconfont 项目

每个业务项目用到的图标肯定是有差异的,我们先选一些图标做个示例,为了方便,这里直接选用了一套阿里云官网官方图标库[13],然后把这些图标抄到自己的图标项目中。

1b10abfc81401c55b3064ba2adc84c50.png

大概看了一下,图标也挺多的,一个个加到购物车手也会很累。于是我观察了一下 DOM 结构,发现可以用脚本模拟一下点击加购物车的行为,那就不浪费时间了,直接上脚本。

[...document.querySelector(".collection-detail ul.block-icon-list").children].forEach(child => {
    child.children[2].children[0].click()
})

e400a467dd22f615e6eb9bd1ef36ee50.gif

图标复制到项目中后发现图标的默认命名有点呆,全是 icon-test11 这样的,辨识度太低。懒得一个个改名字,最后还是换了一个图标库 Hippo Design 官方图标库[14]

了解字体图标的基本原理

顾名思义,字体图标本质上也是利用字体文件来展示图标的。字符的展示是依赖字符编码的,从 ASCII 到 Unicode,字符集也在不断丰富。计算机并不认识文字、符号或图标,本质上都是通过字符编码结合字体文件、排版引擎等来做渲染的。而 Unicode 预留了E000-F8FF范围作为私有保留区域,这个区间的 Unicode 码可以用来自定义一些内容,那么用来做字体图标显然也是非常合适,前端根据 Unicode 码就能显示对应的图标。

PUA[15],即 Private Use Areas,私人使用区相同的代码点可被分配为不同的字符,因此用户可能因安装了某种字体,看到其显示为一种形态,但使用了其他字体的用户可能看到完全不同的字符。

这也就是说,不同的字体文件可以重复利用这个区域的 Unicode,但是可以展示出不同的形态,这也就可以理解为什么我们能展示各种各样的图标了。

然而直接用 Unicode 并不方便记忆和理解,所以我们会在 Unicode 编码基础上再封装一层,通过不同的 class 结合伪元素来表现图标,类似下面这样:

d22c1bc20ce55025ff91b0f1cdac7a00.png

引入字体文件

接上面,你首先需要有一个图标库对应的字体文件,而这个字体文件可以来源于 iconfont。

如果希望偷偷懒,或者不关注 iconfont cdn 的稳定性,你完全可以选择使用在线的 css 文件,这个 css 文件中也会引用在线的 ttf 等字体文件。

6cfb881c35c0bb0d19c968c670db8813.png

如果你关注内容的稳定性,不希望因为 iconfont cdn 问题导致业务损失,那么我建议把相关资源(包括 css 文件及其关联的字体文件)下载到项目中使用。

53236e99738719ef04283e98364c98c1.png

还有一个要考虑的问题,字体文件这些资源放在组件库中加载合适,还是放在业务项目中加载合适?

我想,应该是放在业务项目中加载字体文件等资源比较合适。因为不同的业务项目用到的图标库肯定是有差异的,如果把字体文件内置到图标组件中,就会导致图标库都是一样的,显然没法满足各个项目的需求。

而在我们的 monorepo 工程中,playground就扮演着业务项目的角色,可以用来测试组件库的表现,所以我们先在playground中引入生成的在线 css 文件。

118eb99a6835846cd80f11db9a9dc92e.png

思路整理

字体等资源准备好之后,就可以思考怎么基于这些资源实现组件了。

我们知道,css 文件中已经将各个图标封装成 class 了。

b92f72da918c1595aba4932463e4310b.png

只要我们引用这些 class,就能得到一个字体图标,我们来试试看:

<i class="iconfont vp-icon-layers"></i>
3380e26a607a29e622660cb3c1ff6b26.png

可以发现效果已经出来了。但是我们是写死测试的,要实现一个可复用的图标组件,显然还要预留一些属性交给外部配置,很容易想到的属性有:

  • 图标的名称:用来唯一确认一个图标,一个名称对应一个 class,这个 class 会对应一个唯一的 Unicode 编码。

  • 图标的颜色:字体图标本身也是一个“字”,和普通的字没啥区别,所以可以用color属性控制颜色。

  • 图标的大小:同上,可以用font-size控制图标的大小,但是通过font-size只能控制一个大概的大小,并不等价于绝对意义上的宽高。下面是我设置font-size: 15px的效果,可见真实的高度并不是15px

e0f3fc9f6a5b781988a1f0857a0dbe5d.png

如果你希望控制地很彻底,那就应该另外通过widthheight去控制了。但是我认为大部分情况,没有这个必要,用font-size粗略控制一下字体图标的大小就差不多了。

524f80ad6a491ba2607d646c3ad96990.png
  • 图标的 class 前缀:目前也是写死的 vp-icon-作为前缀,虽然没什么大问题,但是最好留个配置项。

组件属性

我们把属性单独提到一个props.ts中维护,利用 Vue 提供的 ExtractPropTypes 可以把属性的类型提取出来。

27a0aac8308c366e6bd0e2d406dc0321.png

组件主体

e8e992ee653538760d563572618c9e60.png

主体逻辑不是很复杂,首先必须引用一个基本的 class iconfont,这个 class 是用于控制字体等基本属性的。

66f7f1ed80ec2585085398343bdcf572.png

接着通过iconPrefixicon的拼接组成一个完整的class,用来映射到具体的图标。

36d42e58d33e7871f80b4628c6c51207.png

其他的属性colorsize就是辅助控制颜色和大小的。

组件名的处理

组件名可以由文件名自动推断出来,但是为了和文件名解耦,我们还是希望定义一个组件name。但是在 setup 语法糖下,Vue 官方并没有提供类似于defineProps这样的编译宏,让我们方便地定义name,唯一的办法是另外写一个普通的script块,在其中的默认导出中包含name字段,但是这显得很不方便。

ff50987319e296e17f73079194af93d9.png

还好已经有人通过插件解决了这个问题。但是在相关 RFC 的讨论中,似乎尤大也并未完全支持这种做法,具体见 https://github.com/vuejs/rfcs/discussions/430 ,所以是否采纳这种做法还值得考虑一番。

换个思路,咱们先在icon/index.ts中扩展一下name字段。

8d621a1ffc5a4225b3562940f434e25f.png

类型问题 & 插件化

我们可以观察到,在 Volar 的加持下,模板中的组件类型显得还比较完善。

28604f8aaa3cf768cc68568359999891.png

但是在 ts 上下文中,组件的类型似乎还未展示出来。

326925427a1ce98f4f09cec23186475e.png

与此同时,组件还没有对应的install方法,这样就不能单独作为一个插件被use。我们借鉴一下其他 UI 组件库的做法,用一个withInstall函数把组件包装一下。

考虑到这类通用的工具方法还可以要暴露给外部项目使用,我们可以把工具方法封装到@vue-pro-components/utils这个包中。

b1073aa87cf0494b6fcdcfa9afe3634c.png

接着 Icon 的导出部分就可以写成这样了:

36291cb9b9f91e93bd8c3d9f9c09e5a9.png

而且我们能看到,这个时候 Icon 的类型提示也出来了。

a6c2106a5422eb5d2b6099b781aee3ee.png 03a23044a04b4fdb8080655faf54dbcb.png

结语

在本节中,我们继续完善了一些工程化配置,但是在配置上也是点到为止,没有堆砌太多的插件或者配置项,以防让人眼花缭乱,无法抓到重点。接着,我们通过一个字体图标组件需求的实战,初步掌握了如何组织起一个组件。接下来,我们会继续通过一些实战案例查漏补缺,在实际运用中看看我们还缺失一些什么东西。如果您对我的专栏感兴趣,欢迎您订阅关注本专栏[16],接下来可以一同探讨和交流组件库开发过程中遇到的问题。

参考

[1]

基于Vite+AntDesignVue打造业务组件库: https://juejin.cn/column/7140103979697963045

[2]

ESLint: https://eslint.org/

[3]

StyleLint: https://stylelint.io/

[4]

文档: https://prettier.io/docs/en/integrating-with-linters.html

[5]

eslint-config-prettier: https://github.com/prettier/eslint-config-prettier

[6]

stylelint-config-prettier: https://github.com/prettier/stylelint-config-prettier

[7]

eslint-plugin-prettier: https://github.com/prettier/eslint-plugin-prettier

[8]

Prettier: https://github.com/prettier/prettier

[9]

ESLint: https://eslint.org/

[10]

Espree: https://github.com/eslint/espree

[11]

typescript-eslint: https://github.com/typescript-eslint/typescript-eslint

[12]

eslint-import-resolver-typescript: https://github.com/import-js/eslint-import-resolver-typescript

[13]

阿里云官网官方图标库: https://www.iconfont.cn/collections/detail?spm=a313x.7781069.1998910419.d9df05512&cid=16472

[14]

Hippo Design 官方图标库: https://www.iconfont.cn/collections/detail?spm=a313x.7781069.1998910419.d9df05512&cid=22664

[15]

PUA: https://baike.baidu.com/item/%E7%A7%81%E4%BA%BA%E4%BD%BF%E7%94%A8%E5%8C%BA/61727452?fr=aladdin

[16]

https://juejin.cn/column/7140103979697963045: https://juejin.cn/column/7140103979697963045

END

9ad818582d08f3c055e25e3c6f0a703e.png

如果觉得这篇文章还不错

点击下面卡片关注我

来个【分享、点赞、在看】三连支持一下吧f7a41337d5ba8637ce0126b04f25397f.png

   “分享、点赞、在看” 支持一波 d48673b12ce042097ce372c464602042.png 

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

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

相关文章

websocket的用处及vue和SpringBoot和nginx的引入-入门

websocket的用处及vue和SpringBoot的引入-入门 为什么要有websocket 微信 想一个场景&#xff0c;扫码登录&#xff0c;服务器并不知道用户有没有扫码&#xff0c;怎么办&#xff0c;一种办法是HTTP定时轮询&#xff0c;1-2秒就请求一次服务端&#xff0c;看看用户有没有扫码…

5.3 常见的电感式和电容式感测原理及应用

常见的电感式和电容式感测应用1、电感式和电容式工作原理1.1 电感式感测工作原理1.2 电容式感测工作原理2 FDC&#xff1a;电容式液位感测2.1 电容技术在液位感测中的优势2.2 电容式液位感测入门3 LDC&#xff1a;电感式触控按钮4 LDC&#xff1a;增量编码器和事件计数5 LDC&am…

再学C语言10:字符串(1)

一、字符串定义 字符串&#xff1a;一个或多个字符的序列 "hello world!" 双引号并不是字符串的一部分&#xff0c;只是用于通知编译器其中包含了一个字符串 C没有为字符串定义专门的变量类型&#xff0c;而是将其存储在char数组中 字符串中的字符存放在相邻的存…

Amazon 4.7 星评,领域新经典,了解服务设计就读它

2011 年&#xff0c;Adaptive Path 公司的 Brandon Schauer 粗略估算&#xff0c;美国每年在服务的规划和设计上大约花费 20 亿美元&#xff0c;但其中仅有 7000 万美元&#xff08;大约 3.5%&#xff09;花在了“服务设计”上。做另外 96.5% 的工作的那些人&#xff0c;从不觉…

参加大学生数学建模大赛,Matlab和Python到底哪个更好?

前言 后台的小伙伴经常会问编程过程中&#xff0c;MATLAB和Python到底哪个更好&#xff1f;这个问题一直困惑很多同学&#xff0c;今天小编来给大家从实用型来综合分析一下&#xff1a; 首先从两者各自的应用做个对比。 一、python的优势 Python相对于Matlab最大的优势&…

Mac M2芯 k8s(minikube)超详细实战 - 单节点部分

概述 我使用的电脑是Mac pro M2芯的&#xff0c;使用的虚拟环境是 Ubuntu 22.04 &#xff0c;M2芯兼容性不是特别好&#xff0c;所以尽量跟我博客中的版本保持一致。 虚拟机环境 Ubuntu 22.04docker &#xff1a;20.10.17minikube&#xff1a;v1.25.2 搭建minikube虚拟机环境…

【强化学习基础】强化学习的基本概念:状态、动作、智能体、策略、奖励、状态转移、轨迹、回报、价值函数

文章目录1.状态&#xff08;State&#xff09;2.动作&#xff08;Action&#xff09;3.智能体&#xff08;Agent&#xff09;4.策略&#xff08;Policy&#xff09;5.奖励&#xff08;Reward&#xff09;6.状态转移&#xff08;State transition&#xff09;7.智能体与环境交互…

高效率的Python开发工具——PyCharm v2022.3正式发布

JetBrains PyCharm是一种Python IDE&#xff0c;其带有一整套可以帮助用户在使用Python语言开发时提高其效率的工具。此外&#xff0c;该IDE提供了一些高级功能&#xff0c;以用于Django框架下的专业Web开发。 PyCharm v2022.3官方正式版下载(q技术交流&#xff1a;786598704)…

wireshark抓包数据提取TCP/UDP/RTP负载数据方法

wireshark抓包数据提取TCP_UDP_RTP负载数据方法 文章目录wireshark抓包数据提取TCP_UDP_RTP负载数据方法1 背景2 TCP和UDP负载提取方式3 RTP负载提取方式1 背景 在视频抓包分析过程中&#xff0c;有时候需要从TCP、UDP、RTP中直接提取payload数据&#xff0c;比如较老的摄像机…

微课堂助力在线教育招生引流方式_付费视频系统搭建对在线教育的作用

一、借助优惠码线上线下推广课程 1、线下发传单&#xff1a; 机构先在我们后台创建对应课程的通用优惠码&#xff0c;然后再制作课程传单介绍页。传单上显示出对应课程的通用优惠码&#xff0c;线下派发传单给到用户。 2、线下刮刮卡片推广&#xff1a;将私有码制作成卡片配合…

SVM(二)对偶问题转化以及求解

上篇&#xff1a; SVM&#xff08;支持向量机&#xff09;&#xff08;一&#xff09;基本形式推导 凸优化 考虑如下优化问题&#xff1a; 应用拉格朗日乘子法&#xff1a; 定义拉格朗日对偶函数G\mathcal{G}G&#xff0c;这里 infinfinf 是上确界&#xff08;集合的最小上…

超标量处理器设计——第十章_提交

参考《超标量处理器》姚永斌著 文章目录超标量处理器设计——第十章_提交10.1 概述10.2 重排序缓存10.2.1 一般结构10.2.2 端口需求10.3 管理处理器的状态10.3.1 使用ROB管理指令集定义的状态10.3.2 使用物理寄存器管理指令集定义的状态10.4 特殊情况处理10.4.1 分支预测失败的…

【微服务】Nacos ⼀致性协议

目录 一、为什么 Nacos 需要⼀致性协议 二、为什么 Nacos 选择了 Raft 以及 Distro 1、从服务注册发现来看 2、从配置管理来看 3、为什么是 Raft 和 Distro 呢 三、早期的 Nacos ⼀致性协议 四、当前 Nacos 的⼀致性协议层 &#x1f496; Spring家族及微服务系列文章 …

【关于时间序列的ML】项目 2 :使用机器学习预测股票价格

&#x1f50e;大家好&#xff0c;我是Sonhhxg_柒&#xff0c;希望你看完之后&#xff0c;能对你有所帮助&#xff0c;不足请指正&#xff01;共同学习交流&#x1f50e; &#x1f4dd;个人主页&#xff0d;Sonhhxg_柒的博客_CSDN博客 &#x1f4c3; &#x1f381;欢迎各位→点赞…

5G无线技术基础自学系列 | RF优化流程

素材来源&#xff1a;《5G无线网络规划与优化》 一边学习一边整理内容&#xff0c;并与大家分享&#xff0c;侵权即删&#xff0c;谢谢支持&#xff01; 附上汇总贴&#xff1a;5G无线技术基础自学系列 | 汇总_COCOgsta的博客-CSDN博客 在介绍完了RF优化的思路和措施之后&…

【Linux 软件包管理器 yum】

While there is life there is hope. 目录 1 什么是软件包 2 关于 rzsz 3 注意事项 4 查看软件包 5 如何安装软件 6 如何卸载软件 总结 1 什么是软件包 在Linux下安装软件, 一个通常的办法是下载到程序的源代码, 并进行编译, 得到可执行程序. 但是这样太麻烦了, 于是有些人…

[译] 来了解一下 Island Architecture 孤岛架构

建立一个网站有不同的方法&#xff0c;其中之一便是多页应用程序(MPA)&#xff0c;它大约在十年前就过时了&#xff0c;现在又重新流行起来。MPA已经被Angular和React以及其他现代框架所普及的单页应用(SPA)方法所取代。 由于应用软件迭代趋势的运作方式&#xff0c;方法/工具…

异步任务如何测试?

总是能收到这样的问题&#xff1a; 异步任务如何测试&#xff1f;异步的接口如何测试&#xff1f;可以通过自动化来保证异步任务是否执行了吗&#xff1f;能否保证执行是否成功&#xff1f; 收到这样的问题&#xff0c;其实大家的问题都是通用的&#xff0c;那么正好整理下我…

毫无基础的人如何入门 Python ?

Python 我也是从零开始自学的&#xff0c;因为工作的原因&#xff0c;我需要 python 做很多数据抓取的工作。我把自己的学习的感想&#xff0c;做了一下总结&#xff0c;阅读到最后&#xff0c;一定会有惊喜。 首选&#xff0c;我不会一下子&#xff0c;给你推荐一堆视频课程&…

从git上新拉下来的vue项目,没有node_modules依赖,npm install报错,node-sass报错

因为没有node_modules依赖&#xff0c;我直接 1.npm install&#xff0c;但是报错&#xff1a; 2.npm install --force报错 3.npm audit fix --force报错 4.npm install --legacy-peer-deps报错 5.npm install --registry https://registry.npm.taobao.org 直接安装淘宝镜像也…