- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
因此,我在Vue上玩了很多游戏,而现在我的应用变得越来越大,我对如何组织它感到怀疑。
我了解码件,当您需要在同一页面上多次重复使用它们时,它们很有意义,例如,“自定义选择框”组件,在许多地方可能会需要它们。
但是,只有一次实例的组件又如何呢?示例:一个管理仪表板界面,该界面包含3个区域:一个带有一些导航的侧栏,一个可以根据导航中选择的内容进行编辑的主区域,另一个带有与主区域相关的内容的侧栏。所有这些都需要是单独的组件吗?因为如果页面上每个实例只有一个实例,我看不到这样做的任何好处。另一方面,如果我将所有代码填充在单个“app”组件中,则可以简化一些代码(减少变量)
最佳答案
摘要-使用组件的典型原因:
<select-box :some-prop="blah">
<select-box-option v-for="something" />
</select-box>
select-box
。
select-box
的所有繁琐的实现细节都被隐藏了,我们不必担心它们。通过查看 Prop ,子组件和事件,我们可以快速推断出哪些数据在父组件和
select-box
之间往返。这只是关注点分离。
<nav-sidebar @navigate="onNavigate" />
nav-sidebar
没有任何 Prop ,只有一个事件。由此我们可以开始得出关于这些组件如何相互作用的一些结论。看来
nav-sidebar
不需要从主要组件传递的任何内容,它可以很幸福地独立运行。如果需要用另一种方式调试数据流问题,则几乎可以肯定地从
onNavigate
开始。
nav-sidebar
可能做了一些涉及
$parent
的可怕事情,以从其父组件中获取数据。但是,这仅说明了为什么使用这种技术被认为是不好的做法。可维护的代码应允许开发人员根据似乎已到位的抽象,跳到合理的结论。
.js
文件,插件,过滤器,Vuex,mixins等。您可以使用几个选项。
render
函数。运行该
render
函数时,它会注册反应性依赖项,就像计算的属性一样。如果这些依赖项中的任何一项发生更改,它将触发重新渲染。那将再次运行整个
render
函数。即使这不会导致DOM发生任何更改,也将需要生成所有相关的VNode,并且差异算法将需要检查所有这些VNode。
nav-sidebar
为例,假设
nav-sidebar
有所更改,因此需要进行渲染更新。如果
nav-sidebar
是一个单独的组件,则只需为该组件运行template /
render
函数。相反,如果我们将所有
nav-sidebar
代码 bundle 到主模板中,那么我们将不得不重新呈现所有内容。
data
和它自己的计算属性。这听起来很明显,但是当您考虑通过
v-for
循环时,它就变得很重要。
<div v-for="item in items">...</div>
<div v-for="item in items" :class="getClassesFor(item)">...</div>
<my-component v-for="item in items" :item="item" />
my-component
可以保留自己的状态。例如,假设
my-component
具有扩展/折叠功能。现在可以将其存储在每个实例中的本地
data
属性中。同样,每个实例将具有自己的计算属性。
v-for
创建了多个实例。但是,鉴于我们正在专门引入一个新组件以提供一种属性范围,因此我认为值得特别提及。
关于javascript - Vuejs:将代码分布在多个组件或所有组件中吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58487873/
我有两个项目。一个项目正在运行,没有任何问题。它是从 gitlab 下载的。另一个项目是从 github 下载的。 github项目有这个问题。我想使用默认的 gradle 分布。我想知道我做错了什么
我正在通过我学习的大学提供的 VNC 软件(远程访问)使用 IBM bigInsights,但我无法通过该桌面访问 Internet。为了使用互联网上的一些数据样本,我决定安装 Hadoop 在我的笔
所以,这非常简单,我有一个包含嵌套列表的列表,如下所示: List( *list1* List(List("n1", "n3"), List("n1", "n4"), List("n3", "n4")
我有以下示例。 prefix = ['blue ','brown '] suffix = [('dog','shoes','bike'), ('tree','cat','car')] 我想获得一个如下
我创建了一项调查并将其发送出去。该调查要求用户提供电子邮件,然后要求他们从包含 8 个不同选项的下拉菜单中选择要吃哪顿饭。有些人使用同一封电子邮件多次填写调查,但食物选择不同。 我有一个如下所示的 M
我在 Python 中使用 plotly 来创建由某些分类变量着色的美国县的等值线。由于县非常小,因此图像中的边界线占主导地位。我怎样才能摆脱它们(或将它们的宽度设置为零)? 到目前为止的代码和输出(
我们有qgamma在 R 和 gamm.inv在 excel 中,我无法使用 invgamma 获得相同的结果python中的函数。例如在excel中GAMMA.INV(0.99,35,0.08)=4
过去几年我经常使用 Docker,但对于 Kubernetes 来说我还是个新手。我从今天开始,与我以前使用 Docker swarm 的方式相比,我正在努力思考 Pod 概念的实用性。 假设我有一个
我有一个 UIStackView然而,subViews的第一个 View 是 UILabel它没有相应地调整它的大小。 我的代码如下; private let stackView: UIStackVi
我想绘制自由度为 1、2、5 和 10 的 Student t 分布;所有在一个图中,并为图中的每个分布使用不同的颜色。此外,在 Canvas 的左上角创建一个图例,并增加 df = 1 的曲线线宽。
我对 Python 很陌生,我在互联网上浏览过,但找不到任何可以帮助我解决问题的逻辑。 我在图中有降水值,现在我需要根据图中的这些值拟合 GEV 分布。每个值等于从 1974 年到 2017 年的一年
我正在尝试复制此图 https://wind-data.ch/tools/weibull.php 我编写的代码是 import matplotlib.pyplot as plt import nump
对于家庭作业,我必须绘制文本的词频并将其与最佳 zipf 分布进行比较。 根据对数对数图中的排名绘制文本的词频计数似乎效果很好。 但是我在计算最佳 zipf 分布时遇到了麻烦。结果应该如下所示: 我不
Mathematica 具有四参数广义逆 Gamma 分布: http://reference.wolfram.com/mathematica/ref/InverseGammaDistribution
正在用 C 语言开发一个学校项目,使用 Pthreads 将一维数组分解为 tRows 和 tCols 的子矩阵。整个数组的大小为 wRows 和 wCols。假设 wCols = 4、wRows =
有没有办法得到制服int32_t没有警告的分发?我用这个uniform_int_distribution在我的代码中,但我收到警告: 54988961.cpp: In function ‘int ma
在花了相当多的时间试图了解如何在 postgresql 数据库服务器之间实现负载平衡(分配数据库处理负载)之后,我来到这里。 我有一个 postgresql 系统,每秒吸引大约 100 笔交易,而且这
所以标题已经说明了一切。我们正在开发一个开始获得大量依赖项的项目。到目前为止,我们一直在使用 setuptools,但越来越多的依赖项要么不容易安装(例如 wxPython),要么在某些使用 easy
我有以下代码: #include #include #include using namespace boost::numeric; using namespace interval_lib;
我有一个对象列表,我想以随机顺序连续访问这些对象。 我想知道是否有一种方法可以确保随机值并不总是相似。 例子。 我的列表是队列列表,我试图交错这些值以生成用于测试的真实场景。 我并不是特别想要队列 1
我是一名优秀的程序员,十分优秀!