Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Filters #60

Merged
merged 9 commits into from
Mar 7, 2019
2 changes: 1 addition & 1 deletion src/v2/cookbook/serverless-blog.md
Original file line number Diff line number Diff line change
Expand Up @@ -298,7 +298,7 @@ created() {

## Alternative Patterns

An alternative pattern to consider, especially if you prefer writing only in Markdown, is using something like [Nuxtent](https://nuxtent.now.sh/guide/writing#async-components). Nuxtent allows you to use `Vue Component` inside of Markdown files. This approach would be akin to a static site approach (i.e. Jekyll) where you compose your blog posts in Markdown files. Nuxtent adds a nice integration between Vue.js and Markdown allowing you to live in a 100% Vue.js world.
An alternative pattern to consider, especially if you prefer writing only in Markdown, is using something like [Nuxtent](https://nuxtent-module.netlify.com/guide/writing/#async-components). Nuxtent allows you to use `Vue Component` inside of Markdown files. This approach would be akin to a static site approach (i.e. Jekyll) where you compose your blog posts in Markdown files. Nuxtent adds a nice integration between Vue.js and Markdown allowing you to live in a 100% Vue.js world.

## Wrap up

Expand Down
24 changes: 12 additions & 12 deletions src/v2/guide/filters.md
Original file line number Diff line number Diff line change
@@ -1,20 +1,20 @@
---
title: Filters
title: Filter
type: guide
order: 305
---

Vue.js allows you to define filters that can be used to apply common text formatting. Filters are usable in two places: **mustache interpolations and `v-bind` expressions** (the latter supported in 2.1.0+). Filters should be appended to the end of the JavaScript expression, denoted by the "pipe" symbol:
Vue.js memungkinkan Anda untuk menentukan filter yang dapat digunakan untuk memformat tulisan. Filter dapat digunakan di dua tempat: **interpolasi mustache dan ekspresi `v-bind`** (terakhir didukung di 2.1.0+). Filter harus ditambahkan di akhir JavaScript expression dengan simbol "pipe" ( | ):
logustra marked this conversation as resolved.
Show resolved Hide resolved

``` html
<!-- in mustaches -->
<!-- di mustaches -->
{{ message | capitalize }}

<!-- in v-bind -->
<!-- di v-bind -->
<div v-bind:id="rawId | formatId"></div>
```

You can define local filters in a component's options:
Anda dapat menentukan filter lokal dalam opsi komponen:

``` js
filters: {
Expand All @@ -26,7 +26,7 @@ filters: {
}
```

or define a filter globally before creating the Vue instance:
atau menentukan filter secara global sebelum membuat Vue instance:

``` js
Vue.filter('capitalize', function (value) {
Expand All @@ -40,7 +40,7 @@ new Vue({
})
```

Below is an example of our `capitalize` filter being used:
Di bawah ini adalah contoh dari filter `capitalize` yang kami gunakan:

{% raw %}
<div id="example_1" class="demo">
Expand All @@ -66,20 +66,20 @@ Below is an example of our `capitalize` filter being used:
</script>
{% endraw %}

The filter's function always receives the expression's value (the result of the former chain) as its first argument. In the above example, the `capitalize` filter function will receive the value of `message` as its argument.
Filter selalu menerima nilai expressions (hasil dari rantai sebelumnya) sebagai argumen pertama. Dalam contoh di atas, filter `capitalize` akan menerima nilai `message` sebagai argumen.
logustra marked this conversation as resolved.
Show resolved Hide resolved

Filters can be chained:
Filter bisa berantai:

``` html
{{ message | filterA | filterB }}
```

In this case, `filterA`, defined with a single argument, will receive the value of `message`, and then the `filterB` function will be called with the result of `filterA` passed into `filterB`'s single argument.
Pasa kasus ini, `filterA`, didefinisikan dengan satu argumen, yang akan menerima nilai `message`, kemudian `filterB` akan dipanggil dengan hasil dari `filterA` yang akan dilanjutkan ke `filterB` sebagai satu argumen.

Filters are JavaScript functions, therefore they can take arguments:
Filter adalah fungsi JavaScript, oleh karena itu mereka dapat mengambil argumen:

``` html
{{ message | filterA('arg1', arg2) }}
```

Here `filterA` is defined as a function taking three arguments. The value of `message` will be passed into the first argument. The plain string `'arg1'` will be passed into the `filterA` as its second argument, and the value of expression `arg2` will be evaluated and passed in as the third argument.
Di sini `filterA` didefinisikan sebagai fungsi yang mengambil tiga argumen. Nilai `message` yang akan dilanjutkan ke argumen pertama. String `'arg1'` yang akan di lanjutkan ke `filterA` sebagian argumen kedua, dan nilai dari expression `arg2` yang akan dievaluasi dan diteruskan sebagai argumen ketiga.
2 changes: 2 additions & 0 deletions src/v2/guide/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -393,6 +393,8 @@ You may have noticed that Vue components are very similar to **Custom Elements**

2. Vue components provide important features that are not available in plain custom elements, most notably cross-component data flow, custom event communication and build tool integrations.

Although Vue doesn't use custom elements internally, it has [great interoperability](https://custom-elements-everywhere.com/#vue) when it comes to consuming or distributing as custom elements. Vue CLI also supports building Vue components that register themselves as native custom elements.

## Ready for More?

We've briefly introduced the most basic features of Vue.js core - the rest of this guide will cover them and other advanced features with much finer details, so make sure to read through it all!
Expand Down