iis服务器助手广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >一定要知道的 25 个 Vue 技巧
  • 468
分享到

一定要知道的 25 个 Vue 技巧

2024-04-02 19:04:59 468人浏览 泡泡鱼
摘要

目录1. 将 prop 限制为类型列表2. 默认内容和扩展点3. 使用引号观察嵌套值4. 知道何时使用 v-if(以及何时避免使用)5. 单作用域 slot 的简写(不需要模板标签!

1. 将 prop 限制为类型列表

prop 定义中使用 validator 选项,你可以将 prop 限制为一组特定的值:


export default {
  name: 'Image',
  props: {
    src: {
      type: String,
    },
    style: {
      type: String,
      validator: s => ['square', 'rounded'].includes(s)
    }
  }
};

这个 validator 函数接受一个 prop,返回 true false。当你需要比布尔值允许的更多选项时,也可以使用它。按钮类型或警报类型(信息、成功、危险、警告)是一些比较常见的用途。

2. 默认内容和扩展点

Vue 中的slot可以具有默认内容,这使你可以制作更易于使用的组件:


<button class="button" @click="$emit('click')">
  <slot>
    <!-- 如果没有提供slot则使用 -->
    Click me
  </slot>
</button>

基本上你可以获取组件的任何部分,将其包装在一个slot中,然后你可以使用你想要的任何内容覆盖该组件的该部分。默认情况下,它仍然会像往常一样工作,你还可以有更多选择:


<template>
  <button class="button" @click="$emit('click')">
    <!-- 一开始在 slot 标签中添加什么都不做 -->
    <!-- 我们可以通过向 slot 提供内容来覆盖它 -->
    <slot>
      <div class="fORMatting">
        {{ text }}
      </div>
    </slot>
  </button>
</template>

现在你可以以多种不同的方式使用该组件。

简单的默认方式或你自己的自定义方式:


<!-- 使用组件的默认功能 -->
<ButtonWithExtensionPoint text="Formatted text" />

<!-- 使用扩展点创建自定义行为 -->
<ButtonWithExtensionPoint>
  <div class="different-formatting">
    在这里做一些不同的事情
  </div>
</ButtonWithExtensionPoint>

3. 使用引号观察嵌套值

你可能不知道这一点:只需使用引号就可以轻松地直接查看嵌套值:


watch {
  '$route.query.id'() {
    // ...
  }
}

这对于处理深度嵌套的对象非常有用

4. 知道何时使用 v-if(以及何时避免使用)

有时不使用v-if,使用v-show会更高效:


<ComplicatedChart v-show="chartEnabled" />

v-if打开和关闭时,它将完全创建和销毁元素。v-show不同的是将创建元素并将其留在那里,通过将其样式设置为display: none来隐藏它。

如果你需要切换的组件渲染起来代价比较高,那么这样做会更有效率。另一方面,如果你不需要立即使用那个组件,可以使用v-if以便它跳过渲染它并更快地加载页面。

5. 单作用域 slot 的简写(不需要模板标签!)

Scoped slot 比较有趣,但为了使用它们,你也必须使用很多template标签。

然而有一个速记可以让我们摆脱它,但前提是我们使用单个作用域slot

可以不用这样写:


<DataTable>
  <template #header="tableAttributes">
    <TableHeader v-bind="tableAttributes" />
  </template>
</DataTable>

我们可以这样写:


<DataTable #header="tableAttributes">
  <TableHeader v-bind="tableAttributes" />
</DataTable>

这样更简单、直接。

6. 有条件地渲染slot

每个 Vue 组件都有一个特殊的 $slots 对象,其中包含所有slot。 默认slot具有默认键,名字命名的slot都使用它们的名称作为键:


const $slots = {
  default: <default slot>,
  icon: <icon slot>,
  button: <button slot>,
};

但是这个$slots对象只有应用于组件的slot,而不是每个定义的slot

以这个定义了几个slot的组件为例,包括几个命名的slot:


<!-- Slots.vue -->
<template>
  <div>
    <h2>这里是一些slots</h2>
    <slot />
    <slot name="second" />
    <slot name="third" />
  </div>
</template>

如果我们只对组件应用一个slot,则只有该slot会出现在我们的$slots对象中:


<template>
  <Slots>
    <template #second>
      这将应用于第二个slot
    </template>
  </Slots>
</template>

$slots = { second: <vnode> }

我们可以在我们的组件中使用它来检测哪些slot已应用于组件,

例如:通过隐藏slot的包装元素:\


<template>
  <div>
    <h2>一个包裹的slot</h2>
    <div v-if="$slots.default" class="styles">
      <slot />
    </div>
  </div>
</template>

现在div,应用样式的包装器只有在我们实际用某些东西填充该slot时才会呈现。

如果我们不使用v-ifdiv如果我们没有slot,我们最终会得到一个空的和不必要的。根据所div具有的样式,这可能会弄乱我们的布局并使事情看起来很奇怪。

6.1 为什么我们希望能够有条件地渲染slot呢?

使用条件slot主要有以下三个原因:

  • 使用 wrapper div 来添加默认样式时
  • slot是空的
  • 当我们将默认内容与嵌套slot组合

例如,当我们添加默认样式时,我们会在slot周围添加一个div:


<template>
  <div>
    <h2>This is a pretty great component, amirite?</h2>
    <div class="default-styling">
      <slot >
    </div>
    <button @click="$emit('click')">Click me!</button>
  </div>
</template>

但是,如果父组件没有将内容应用到该slot,我们最终会在页面div上呈现一个空的:\


<div>
  <h2>这是一个非常棒的组件</h2>
  <div class="default-styling">
    <!-- slot中没有内容,但仍会呈现此 div-->
  </div>
  <button @click="$emit('click')">Click me!</button>
</div>

v-if在包装上添加它div可以解决问题。没有应用到slot的内容?像这样:\


<div>
  <h2>这是一个非常棒的组件</h2>
  <button @click="$emit('click')">Click me!</button>
</div>

7. 如何观察slot的变化

有时我们需要知道slot内的内容什么时候发生了变化:


<!-- 可惜这个活动不存在 -->
<slot @change="update" />

可惜 Vue 没有内置的方法来检测这一点,使用突变观察器一种非常简洁的方法:


export default {
  mounted() {
    // 当事情发生变化时调用`update`
    const observer = new MutationObserver(this.update);

    // 观察这个组件的变化
    observer.observe(this.$el, {
      childList: true,
      subtree: true
    });
  }
};

8. 将本地和全局风格混合在一起

通常在使用样式时我们希望它们被限定为单个组件:


<style scoped>
  .component {
    background: green;
  }
</style>

如果你需要还可以添加一个非作用域样式块来添加全局样式:


<style>
  
  .component p {
    margin-bottom: 16px;
  }
</style>

<style scoped>
  
  .component {
    background: green;
  }
</style>

9. 覆盖子组件的样式——正确的方法

Scoped CSS 比较容易保持整洁,并且不会意外地将样式渗入应用程序的其他部分。但有时你需要覆盖子组件的样式,并突破该范围。

Vue 有一个deep专门用于此的选择器:


<style scoped>

.my-component >>> .child-component {
  font-size: 24px;
}
</style>

注意:如果你使用的是 SCSS 之类的 CSS 预处理器,则可能需要改用/deep/。

10. 用上下文感知组件创造魔法

上下文感知组件是“神奇的”——它们可以自动适应周围发生的事情,处理边缘情况,状态共享等等。有 3 种主要类型的上下文感知组件,但是我觉得配置是其中最有趣的一种。

10.1 状态共享

当你将一个大组件分解成多个小组件时,它们通常仍然需要共享状态。你可以“在幕后”实现这一点,而不是将这项工作推给使用组件的人。

可以将一个Dropdown组件分解为SelectOption组件以提供更大的灵活性。但是为了更容易使用,Select和Option组件彼此共享selected状态:


<!-- 为简单起见用作单个组件 -->
<Dropdown v-model="selected" :options="[]" />

<!-- 拆分以获得更大的灵活性 -->
<Select v-model="selected">
  <Option value="mustard">Mustard</Option>
  <Option value="ketchup">Ketchup</Option>
  <div class="relish-wrapper">
    <Option value="relish">Relish</Option>
  </div>
</Select>

10.2 配置

有时需要根据应用程序其余部分的情况更改组件的行为。这样做通常是为了自动处理边缘情况,否则会很麻烦。Popup或者Tooltip应该重新定位自己,这样它就不会溢出页面。但是,如果该组件位于 modal 内部,则它应该重新定位自身,以免溢出modal。如果Tooltip知道它何时在模态内,这可以自动完成。

10.3 造型

当你创建了上下文感知 CSS,根据父元素或兄弟元素中发生的情况应用不同的样式。


.statistic {
  color: black;
  font-size: 24px;
  font-weight: bold;
}


.statistic + .statistic {
  margin-left: 10px;
}

CSS 中变量让我们更进一步允许我们在页面的不同部分设置不同的值。

11. 如何使在 Vue 之外创建的变量具有响应性?

如果你从 Vue 外部获得一个变量,那么能够使其具有响应性就很好。这样你就可以在计算道具、观察者和其他任何地方使用它,它就像 Vue 中的任何其他状态一样工作。

当你正在使用 options API,你只需将它放在data组件的部分中:


const externalVariable = getValue();

export default {
  data() {
    return {
      ReactiveVariable: externalVariable,
    };
  }
};

当你在 Vue 3 中使用组合 api,则可以使用refreactive这样:


import { ref } from 'vue';

// 可以完全在 Vue 组件之外完成
const externalVariable = getValue();
const reactiveVariable = ref(externalVariable);

// 使用 .value 访问
console.log(reactiveVariable.value);

使用reactive来代替:\

import { reactive } from 'vue';

// 可以完全在 Vue 组件之外完成
const externalVariable = getValue();
// Reactive 仅适用于对象和数组
const anotherReactiveVariable = reactive(externalVariable);

// 直接访问
console.log(anotherReactiveVariable);

如果你仍在使用 Vue 2(就像我们中的许多人一样),你可以使用observable而不是reactive获得完全相同的结果。

12. 在 v-for 中解构

你知道你可以在 v-for 中解构吗?


<li
  v-for="{ name, id } in users"
  :key="id"
>
  {{ name }}
</li>

众所周知,你可以使用这样的元组从 v-for 中获取索引:


<li v-for="(value, key) in [
  'Hai Yong',
  'Frozen',
  'WEB Beginner'
]">
  {{ index + 1 }} - {{ value }}
</li>

使用对象时,你还可以抓住key:


<li v-for="(value, key) in {
  name: 'Hai Yong',
  released: 2021,
  director: 'A blogger',
}">
  {{ key }}: {{ value }}
</li>

也可以结合这两种方法,获取属性的键和索引:


<li v-for="(value, key, index) in {
  name: 'Hai Yong',
  released: 2021,
  director: 'A blogger',
}">
  #{{ index + 1 }}. {{ key }}: {{ value }}
</li>

13. 在 Vue 中循环一个范围

v-for指令允许我们遍历一个数组,但它也让我们遍历一个范围:


<template>
  <ul>
    <li v-for="n in 5">项目#{{ n }}</li>
  </ul>
</template>


显示效果:

项目#1
项目#2
项目#3
项目#4
项目#5

当我们使用v-for范围时,它将从 1 开始并以我们指定的数字结束。

14. 观察组件中的任何内容

你的组件中的任何响应都可以被观察到:


export default {
  computed: {
    someComputedProperty() {
      // 更新计算道具
    },
  },
  watch: {
    someComputedProperty() {
      // 当计算的 prop 更新时做一些事情
    }
  }
};

你可以看:

  • 计算道具
  • 道具
  • 嵌套值

如果你使用组合 API,只要它是一个refreactive对象就可以监视任何值,。

15. 窃取道具类型

从子组件复制 prop 类型,只是为了在父组件中使用它们。但窃取这些道具类型比只是复制它们要好得多。

例如,我们Icon在这个组件中使用了一个组件:


<template>
  <div>
    <h2>{{ heading }}</h2>
    <Icon
      :type="iconType"
      :size="iconSize"
      :colour="iconColour"
    />
  </div>
</template>

为了让它工作,我们需要添加正确的道具类型,从Icon组件中复制:\


import Icon from './Icon';
export default {
  components: { Icon },
  props: {
    iconType: {
      type: String,
      required: true,
    },
    iconSize: {
      type: String,
      default: 'medium',
      validator: size => [
        'small',
        'medium',
        'large',
        'x-large'
      ].includes(size),
    },
    iconColour: {
      type: String,
      default: 'black',
    },
    heading: {
      type: String,
      required: true,
    },
  },
};

Icon组件的 prop 类型更新时,你肯定你会忘记回到这个组件并更新它们。随着时间的推移,随着该组件的 prop 类型开始偏离组件中的 prop 类型,将引入错误Icon

所以这就是为什么我们会窃取它们:


import Icon from './Icon';
export default {
  components: { Icon },
  props: {
    ...Icon.props,
    heading: {
      type: String,
      required: true,
    },
  },
};

除了在我们的示例中,我们在每个道具名称的开头添加了“icon” 所以我们必须做一些额外的工作来实现这一点:


import Icon from './Icon';

const iconProps = {};

// Do some processing beforehand
Object.entries(Icon.props).forEach((key, val) => {
  iconProps[`icon${key[0].toUpperCase()}${key.substring(1)}`] = val;
});

export default {
  components: { Icon },
  props: {
    ...iconProps,
    heading: {
      type: String,
      required: true,
    },
  },
};

现在,如果Icon组件中的 prop 类型被修改,我们的组件将保持最新。

但是如果在Icon组件中添加或删除了一个 prop 类型呢?为了涵盖这些情况,我们可以使用v-bind计算道具来保持动态。

16. 检测元素外部(或内部)的点击

有时我们需要检测点击是发生在特定元素el的内部还是外部。这是我们通常使用的方法:


window.addEventListener('mousedown', e => {
  // 获取被点击的元素
  const clickedEl = e.target;

  // `el` 是你正在检测外部点击的元素
  if (el.contains(clickedEl)) {
    // 单击“el”内部
  } else {
    // 在`el`之外点击
  }
});

17. 递归槽

我们是否可以v-for只使用模板来制作一个组件?在此过程中,我发现了如何递归地使用slot

这是组件的样子:


<!-- VFor.vue -->
<template>
    <div>
        <!-- 渲染第一项 -->
    {{ list[0] }}
        <!-- 如果我们有更多的项目可以继续,但需要离开我们刚刚渲染的项目 -->
    <v-for
      v-if="list.length > 1"
            :list="list.slice(1)"
        />
    </div>
</template>

如果你想用作用域slot来做这件事——为什么不呢?!— 只需要进行一些调整:<


template>
  <div>
    <!-- 将项目传递到要渲染的slot中 -->
    <slot v-bind:item="list[0]">
      <!-- Default -->
      {{ list[0] }}
    </slot>

    <v-for
      v-if="list.length > 1"
      :list="list.slice(1)"
    >
      <!-- 递归向下传递作用域slot -->
      <template v-slot="{ item }">
        <slot v-bind:item="item" />
      </template>
    </v-for>
  </div>
</template>

以下是该组件的使用方法:


<template>
  <div>
    <!-- 常规列表 -->
    <v-for :list="list" />

    <!-- 带有粗体项目的列表 -->
    <v-for :list="list">
      <template v-slot="{ item }">
        <strong>{{ item }}</strong>
      </template>
    </v-for>
  </div>
</template>

18. 组件元数据

并不是你添加到组件的每一点信息都是状态。有时你需要添加一些元数据来为其他组件提供更多信息。

例如:如果你要为 Google Analytics 等分析仪表板构建一堆不同的小部件:

如果你希望布局知道每个小部件应占用多少列,你可以将其作为元数据直接添加到组件上:


export default {
  name: 'LiveUsersWidget',
  // 👇 只需将其添加为额外属性
  columns: 3,
  props: {
    // ...
  },
  data() {
    return {
      //...
    };
  },
};

你会发现此元数据是组件上的一个属性:


import LiveUsersWidget from './LiveUsersWidget.vue';
const { columns } = LiveUsersWidget;

你还可以通过特殊$options属性从组件内部访问元数据:


export default {
  name: 'LiveUsersWidget',
  columns: 3,
  created() {
    // 👇 `$options` 包含组件的所有元数据
    console.log(`Using ${this.$options.metadata} columns`);
  },
};

请记住,此元数据对于组件的每个实例都是相同的,并且不是响应式的。

其他用途包括(但不限于):

  • 保留各个组件的版本号
  • 用于构建工具的自定义标志以区别对待组件
  • 向组件添加自定义功能,超出计算道具、数据、观察者等。

19. 多文件单文件组件

这是 SFC 的一个鲜为人知的功能。你可以像使用常规 HTML 文件一样导入文件:


<!-- "single" 文件组件 -->
<template src="./template.html"></template>
<script src="./script.js"></script>
<style scoped src="./styles.css"></style>

如果你需要共享样式、文档或其他任何内容这会很方便。也非常适合那些因滚动而磨损手指的超长组件文件

20. 可重用组件不是你想的那样

可重用组件不一定是大的或复杂的东西,我经常使小而短的组件可重复使用。因为我不会到处重写这段代码,更新它变得容易得多,而且我可以确保每个OverflowMenu看起来和工作完全一样——因为它们是一样的!


<!-- OverflowMenu.vue -->
<template>
  <Menu>
    <!-- 添加自定义按钮来触发我们的菜单 -->
    <template #button v-slot="bind">
      <!-- 使用 bind 传递点击处理程序、a11y 属性等。 -->
      <Button v-bind="bind">
        <!-- 使用我们自己的“...”图标,此按钮没有文字 -->
        <template #icon>
          <svg src="./ellipsis.svg" />
        </template>
      </Button>
    </template>
  </Menu>
</template>

这里我们使用了一个Menu组件,但是在触发它打开的按钮上添加了一个“...”(省略号)图标。可能并不不值得用它来制作可重用的组件,因为它只有几行。每次我们想使用Menu这样的时候,我们不能只添加图标吗?但这OverflowMenu将使用数十次,现在如果我们想要更新图标或其行为,我们可以很容易地做到。而且使用起来也简单多了!


<template>
  <OverflowMenu
    :menu-items="items"
    @click="handleMenuClick"
  />
</template>

21. 从组件外部调用方法

你可以通过给它一个从组件外部调用方法ref:


<!-- Parent.vue -->
<template>
  <ChildComponent ref="child" />
</template>

 
// Parent.vue 中的某个地方
this.$refs.child.method();

通常,我们使用道具和事件在组件之间进行通信。道具被发送到子组件,事件被发送回父组件。


<template>
  <ChildComponent
    :tell-me-what-to-do="someInstructions"
    @something-happened="hereIWillHelpYouWithThat"
  />
</template>

但有时你可能会遇到需要父组件触发子组件中的方法的情况。这是只有向下传递道具不起作用的地方。

可以向下传递一个布尔值并让子组件监视它:


<!-- Parent.vue -->
<template>
  <ChildComponent :trigger="shouldCallMethod" />
</template>

// Child.vue
export default {
  props: ['trigger'],
  watch: {
    shouldCallMethod(newVal) {
      if (newVal) {
        // 当触发器设置为 `true` 时调用该方法
        this.method();
      }
    }
  }
}

这工作正常,但仅限于第一次调用。如果你需要多次触发此操作,则必须清理并重置状态。然后逻辑看起来像这样:

  • Parent 组件传递truetriggerprop
  • Watch被触发,Child组件调用方法
  • Child 组件发出一个事件告诉 Parent 组件该方法已成功触发
  • Parent 组件重置triggerfalse,因此我们可以再次执行此操作

相反,如果我们在子组件上设置ref ,我们可以直接调用该方法:


<!-- Parent.vue -->
<template>
  <ChildComponent ref="child" />
</template>

// Parent.vue 中的某个地方
this.$refs.child.method();

我们打破了“props down, events up”规则,打破了封装,但它更清晰、更容易理解值得这样做!

有时,“最佳”解决方案最终会成为最差的解决方案。

22. 观察数组和对象

使用观察者最棘手的部分是有时候它似乎不能正确触发。一般都是因为你试图查看一个数组或一个对象,但没有设置deeptrue


export default {
  name: 'ColourChange',
  props: {
    colours: {
      type: Array,
      required: true,
    },
  },
  watch: {
    // 使用对象语法而不仅仅是方法
    colours: {
      // 这将让 Vue 知道查看数组内部
      deep: true,

      // 我们必须将我们的方法移动到处理程序字段
      handler()
        console.log('颜色列表已更改!');
      }
    }
  }
}

使用 Vue 3 的反应式 API 看起来像这样


watch(
  colours,
  () => {
    console.log('颜色列表已更改!');
  },
  {
    deep: true,
  }
);

如果你想了解更多信息,可以参阅Vue 3和Vue 2的文档。

23. 与 Vue Router 深度链接

你可以在 URL 中存储(一些)状态,允许你直接跳转到页面上的特定状态。

比如你可以加载一个已选择日期范围过滤器的页面:


someurl.com/edit?date-range=last-week

这对于用户可能共享大量链接的应用程序部分、服务器呈现的应用程序或在两个独立应用程序之间传递比常规链接通常提供的信息更多的信息非常有用。

你可以存储过滤器、搜索值、模式是打开还是关闭,或者我们滚动到的列表中的位置——非常适合无限分页。

使用vue-router这样的方式获取查询(这也适用于 Nuxt 和 Vuepress 等大多数 Vue 框架):


const dateRange = this.$route.query.dateRange;

要更改它,我们使用RouterLink组件并更新query:


<RouterLink :to="{
  query: {
    dateRange: newDateRange
  }
}">

24. 模板标签的另一种用途

template标签可以在模板内的任何地方使用,以更好地组织代码。

我喜欢用它来简化v-if逻辑,有时v-for也是。

在这个例子中,我们有几个元素都使用相同的v-if条件:\


<template>
  <div class="card">
    <img src="imgPath" />
    <h3>
      {{ title }}
    </h3>
    <h4 v-if="expanded">
      {{ subheading }}
    </h4>
    <div v-if="expanded" class="card-content">
      <slot/>
    </div>
    <SocialShare v-if="expanded" />
  </div>
</template>

这有点笨拙,一开始并不明显,一堆这些元素被显示和隐藏在一起。在更大、更复杂的组件上,这可能是更糟糕的情况!

但我们可以解决这个问题。

我们可以使用template标签对这些元素进行分组,并将其提升v-if到template标签本身:\


<template>
  <div class="card">
    <img src="imgPath" />
    <h3>
      {{ title }}
    </h3>
    <template v-if="expanded">
      <h4>
        {{ subheading }}
      </h4>
      <div class="card-content">
        <slot/>
      </div>
      <SocialShare/>
    </template>
  </div>
</template>

25. 处理错误(和警告)的更好方法

你可以为 Vue 中的错误和警告提供自定义处理程序:


// Vue 3
const app = createApp(App);
app.config.errorHandler = (err) => {
  alert(err);
};

// Vue 2
Vue.config.errorHandler = (err) => {
  alert(err);
};

Bugsnag Rollbar 等错误跟踪服务挂接到这些处理程序中以记录错误,但你也可以使用它们来更优雅地处理错误以获得更好的用户体验。

例如,如果错误未得到处理,应用程序不仅会崩溃,还可以显示整页错误屏幕并让用户刷新或尝试其他操作。

在 Vue 3 中,错误处理程序仅适用于模板和观察程序错误,但 Vue 2 错误处理程序几乎可以捕获所有内容。两个版本中的警告处理程序仅适用于开发

到此这篇关于一定要知道的 25 个 Vue 技巧的文章就介绍到这了,更多相关Vue 技巧内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 一定要知道的 25 个 Vue 技巧

本文链接: https://www.lsjlt.com/news/156170.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 一定要知道的 25 个 Vue 技巧
    目录1. 将 prop 限制为类型列表2. 默认内容和扩展点3. 使用引号观察嵌套值4. 知道何时使用 v-if(以及何时避免使用)5. 单作用域 slot 的简写(不需要模板标签!...
    99+
    2024-04-02
  • 学习JavaScript一定要知道的3个小技巧
    目录一、神奇的扩展运算符 1.拷贝数组 2.合并数组 3.展开对象 二、进行空检查的最佳方法 1.可选链操作符 2.空值合并运算符 三、使用 .map()、.reduce() 和 ....
    99+
    2024-04-02
  • 15个Vue技巧,你都知道吗
    目录前言1、将一个prop限制在一个类型的列表中2、使用引号来监听嵌套属性3、知道何时使用v-if4、单个作用域插槽的简写5、将局部和全局的style混合在一起6、重写子组件的样式7...
    99+
    2024-04-02
  • JavaScript需要知道的小技巧有哪些
    这篇文章主要介绍JavaScript需要知道的小技巧有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、神奇的扩展运算符扩展运算符(spread)是三个点( ... ), 可以说我在 JavaScript 中最喜...
    99+
    2023-06-22
  • 10个SpringBoot参数验证你需要知道的技巧分享
    目录前言1.使用验证注解2.使用自定义验证注解3.在服务器端验证4.提供有意义的错误信息5.将 i18n 用于错误消息6.使用分组验证7.对复杂逻辑使用跨域验证8.对验证错误使用异常...
    99+
    2023-05-14
    SpringBoot参数验证技巧 SpringBoot参数验证 SpringBoot 验证
  • JavaScript的这5个技巧你知道了吗
    JavaScript的这5个技巧你知道了吗,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。谁要是说 JavaScript 是世界上比较好的语言,...
    99+
    2024-04-02
  • “Java IDE 重定向:你需要知道的打包技巧是什么?”
    Java IDE 重定向:你需要知道的打包技巧是什么? 在Java开发中,一个好的IDE可以让开发人员事半功倍。在编写Java代码时,IDE可以为开发人员提供各种有用的功能,包括代码补全、调试、重构等。但是,在将应用程序打包和部署到生产环境...
    99+
    2023-08-19
    ide 重定向 打包
  • JavaScript和Python:你需要知道的开发技巧。
    JavaScript和Python:你需要知道的开发技巧 JavaScript和Python是两种广泛应用于Web开发、数据科学等领域的编程语言。这两种语言各自有其独特的特点和用途,但它们也有很多相似之处。在本文中,我们将介绍一些JavaS...
    99+
    2023-08-08
    apache npm javascript
  • Vue开发必须知道的技巧有哪些
    这篇文章主要介绍“Vue开发必须知道的技巧有哪些”,在日常操作中,相信很多人在Vue开发必须知道的技巧有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue开发必须知道的...
    99+
    2024-04-02
  • Python 处理大数据重定向:5个必须知道的技巧
    在现代计算机时代,数据量已经变得越来越大。因此,如何处理大数据并且进行有效的分析,已经成为了每个数据科学家的必修课。Python 作为一种流行的编程语言,它的高效性和灵活性赢得了越来越多的关注。Python 处理大数据时,经常需要进行重定...
    99+
    2023-10-18
    大数据 重定向 load
  • ASP和NumPy:你需要知道的面试技巧和技能
    在当今互联网时代,ASP和NumPy是两个非常重要的技能,无论是在求职面试还是日常工作中,它们都是不可或缺的。本文将为大家介绍ASP和NumPy的基本概念、使用技巧以及相关面试问题。同时,本文还将穿插一些演示代码,帮助读者更好地理解ASP...
    99+
    2023-10-14
    numpy 面试 日志
  • 同步 Go 和 LeetCode,你需要知道的 Linux 技巧!
    随着互联网技术的飞速发展,编程语言和算法竞赛也越来越受到关注。Go 语言和 LeetCode 算法竞赛是当前热门的话题之一。而且在 Linux 操作系统下进行编程和算法竞赛也是很常见的。在本文中,我们将讨论如何在 Linux 操作系统下同...
    99+
    2023-08-11
    linux leetcode 同步
  • Windows 平台下的 Javascript 开发技术,你需要知道的几个实用技巧。
    Javascript 作为一门非常流行的编程语言,已经成为了 Web 开发中不可或缺的一部分。随着技术的不断发展,Javascript 的应用范围也不断扩大,从前端到后端,从浏览器到桌面应用,Javascript 已经成为了一门非常强大的...
    99+
    2023-06-19
    开发技术 windows javascript
  • 学习ASP框架的10个技巧,你知道几个?
    ASP框架(Active Server Pages)是微软公司推出的一种服务器端脚本语言,用于动态创建交互式网页和Web应用程序。ASP框架是一种非常流行的Web开发框架,因为它可以轻松地与其他Microsoft技术(如SQL Serve...
    99+
    2023-08-05
    框架 教程 学习笔记
  • 重定向函数的Python和Laravel实现:您需要知道的一些技巧和窍门
    重定向函数是Web开发中非常常见的功能,它可以让用户在浏览器中访问某个页面时,自动跳转到另一个页面。在本文中,我们将介绍重定向函数在Python和Laravel中的实现方法,并分享一些技巧和窍门。 一、Python中的重定向函数 Pytho...
    99+
    2023-10-22
    laravel 函数 重定向
  • 你需要知道的Go教程中的数组技巧
    在Go语言中,数组是一种常见的数据类型,它可以存储一组相同类型的元素。数组在许多编程语言中都是重要的数据结构,Go语言也不例外。如果你是一个Go语言的开发者,你需要了解一些数组技巧,以便更好地利用这个数据类型。在本文中,我将为你介绍一些。...
    99+
    2023-11-04
    教程 数组 django
  • Python 同步接口 leetcode:您需要知道的技巧和技能。
    在当今世界,计算机科学和编程成为了人们生活中不可或缺的一部分。随着技术的不断发展,越来越多的人开始学习编程,并且Python成为了最流行的编程语言之一。Python的简洁和易读性使其成为初学者的首选,同时也深受专业程序员的喜爱。而在Pyt...
    99+
    2023-10-23
    同步 接口 leetcode
  • Java和Unix日志:你需要知道的打包技巧。
    在软件开发和运维过程中,日志是非常重要的一环。通过日志,我们可以快速定位和解决问题,监控系统运行状态,以及进行数据分析等。Java和Unix是常用的技术栈,下面介绍一些日志打包的技巧,帮助你更好地利用日志。 一、Java日志打包 Java...
    99+
    2023-11-14
    unix 日志 打包
  • 你需要知道的Python Git关键字加载技巧。
    Python和Git都是非常流行的开源工具,Python作为一种高级编程语言,被广泛应用于各种领域,Git则是一种分布式版本控制系统,用于管理软件开发中的源代码和版本控制。在使用Python和Git时,掌握一些关键字加载技巧可以大大提高效率...
    99+
    2023-09-18
    git load 关键字
  • Spring异步编程的5个技巧:你知道吗?
    在现代的Web应用程序中,异步编程已经成为了不可或缺的一部分。Spring框架是一个非常流行的Java开发框架,它提供了多种异步编程的方式来帮助开发人员构建高效的Web应用程序。在本文中,我们将介绍Spring异步编程的5个技巧,让你更好...
    99+
    2023-10-08
    django spring 异步编程
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作