首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

9个不错的前端开源项目

无论您是刚开始编程还是已经是一名经验丰富的开发人员,在这个行业中,学习新的概念和语言/框架是跟上快速变化的必要条件。...为了帮助你在2020年成为前端大师,我收集了9个不同的项目,每个项目都有不同的主题和不同的JavaScript框架或库作为技术栈,您可以构建它们并将它们添加到学习计划中。...该项目将向您展示如何构建一个如下所示的电子商务购物车: ? 您将学到什么 在这个项目中,您将学习如何设置一个Next.js开发环境——创建新页面和组件、获取数据、设置样式并部署下一个应用程序。...它利用了Nuxt必须提供的许多很酷的功能,例如页面和组件以及SCSS的样式。...两者都使用GraphQL作为数据层,但是Gridsome使用VueJS。这也是一个很棒的静态网站生成器,可帮助您创建出色的博客: ?

7K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    vuejs中的组件以及父子组件间通信传值

    ,需借助原生方法或者jQuery提供的方法操作dom,而vuejs,它关注点是数据,数据是什么,就让页面显示什么,并通过在模板中绑定指令,属性的方式与数据进行关联,数据与方法进行分离,数据驱动实现页面的渲染...,也可以监听子组件触发的自定义事件(这在子组件向父组件传值的时候,子组件通过$emit内置的实例方法触发自定义事件,这个自定义事件是写绑定在父组件上的,这个特别重要) v-bind:绑定内联html标签元素的属性...指令绑定自定义属性值的方式,父组件中的数据,可以通过v-for循环列表拿到数据 在上面的时例代码中,通过自定义一个content变量属性用来接收父组件中的数据,v-bind:content="item"...光这样是不够的,还需要在子组件里去接收父组件自定义的这个content变量,在子组件中是通过props这个属性来接收父组件的数据,后面的值可以是数组,也可以是对象,对象允许配置高级选项,如类型检测、自定义校验和设置默认值...(父组件向子组件传值,自定义属性,子组件通过props进行接收) 上面示例代码中,实现父组件向子组件传值添加操作,那么现在我想点击每个列表项的时候,能进行逐条删除操作,该怎么实现呢,这就涉及到子组件向父组件传值的问题了

    20.5K10

    博客生成静态站点工具 Top 20

    提供更好的阅读体验,如可以自由跳转,添加评论等。 此外,将生成电子书形式的静态站点,可以托管到其他平台,达到了备份的效果。...通过 GitBook CLI,用户可以使用命令行界面创建新书、添加章节和页面、选择主题和插件,以及构建和发布书籍。...VuePress 的目标是用于快速搭建文档型网站,并且可以支持自定义主题、插件等功能。 VuePress 使用 Markdown 来写作和生成网站内容,同时支持 Vue 组件和自定义页面。...可以使用多种主题和插件来自定义文档页面,使其更具有个性化和专业性。 支持多种扩展功能,如搜索、站点导航、代码高亮等。 可以与Git等版本控制系统集成,方便协作和管理文档。...15.Gridsome star 数 8.5K+。 Gridsome 是一个基于 Vue.js 的静态网站生成器,它使用 GraphQL 来获取数据并生成静态页面。

    3.8K21

    23、一看就懂父子组件之间的传值

    Github:https://github.com/Ewall1106/mall(请选择分支chapter23) 1、父组件向子组件传值 (1)第一个就是要明白怎么在父页面中向子组件中传值?...(2)第二个就是要知道如何在子组件中接受父页面传过来的值,有几点需要了解: 组件实例的作用域是孤立的; 子组件要显式的用props选项声明它预期的数据,如: // 某个子组件中: export default...以上就是单向数据流的一般表现了: 父级 prop 的更新会向下流动到子组件中,但是反过来则不行。 2、子组件向父组件传值 那么我们延伸一下,子组件怎么向父组件传值?...(2)举例说明 父组件在组件上定义了一个自定义事件childFn,事件名为parentFn用于接受子组件传过来的message值。 <!...参考学习 https://cn.vuejs.org/v2/guide/components-props.html

    3.2K30

    【编程鹿】学Vue.js这一篇就够了「万字学会|通俗易懂」上篇

    : name :这里指定了一个name属性 el :是element的缩写,通过id 选中要渲染的页面元素,本例中是一个 div data:数据,数据是一个对象,里面有很多属性,都可以渲染到视图中 页面中的...h2 元素中,通过{{name}} 的方式,来渲染刚刚定义的 name 属性 更神奇的在于,当你修改name属性时,页面会跟着变化。...: { name: "Vue测试", num: 1 } }); 在data中添加了新的属性...事件处理 在页面添加一个按钮: 向子传递 父组件使用子组件时,自定义属性(属性名任意,属性值为要传递的数据) 子组件通过props接收父组件属性 父组件使用子组件,并自定义了title属性: <

    12.4K20

    如何在Vue中动态添加类名

    作者:Michael Thiessen 译者:前端小智 来源:forum.vuejs.org/ 能够向组件添加动态类名是非常强大的功能。...它使我们可以更轻松地编写自定义主题,根据组件的状态添加类,还可以编写依赖于样式的组件的不同变体。 添加动态类名与在组件中添加 prop :class="classname"一样简单。...在本文中,我们将讨论很多内容: 在 Vue 中使用静态和动态类 如何使用常规的 JS 表达式来计算我们的类 动态类名的数组语法 对象语法 快速生成类名 如何在自定义组件上使用动态类名 静态和动态类 在Vue...中,我们可以向组件添加静态类和动态类。...现在我们已经介绍了向Vue组件动态添加类的基础知识。那么如何使用自己的自定义组件来做到这一点?

    6.2K10

    如何实现 Vue 自定义组件中 hover 事件以及 v-model

    接着我们来看看如何在自定义组件中 实现 v-model。...虽然v-model是向普通组件添加双向数据绑定的强大功能,但是如何向自己的自定义组件添加对v-model的支持并不总是那么容易,但其实很简单。...v-model 介绍 要了解如何在组件中实现v-model支持,需要了解它是如何工作的。...高级用法 通过使用一个或多个计算属性,我们可以将输入数据(如字符串)反规范化为输入元素更容易处理的格式。这通常与更高级的定制组件一起使用,这些组件必须处理各种可能的输入格式,比如颜色选择器。...这是在自己的自定义组件中添加双向数据绑定支持的一种非常简单但功能强大的方法。

    20.9K10

    Vue开发、学习笔记,持续记录

    在向具名插槽提供内容的时候,我们可以在一个  元素上使用 v-slot 指令,并以 v-slot 的参数的形式提供其名称: v-slot (简写#)只能添加在 template上(#...动态指令参数 可以给指令添加动态的参数;如v-bind的绑定的属性名、v-on的事件名、v-slot的插槽名;([任意JS表达式]) v-mydirective:[argument]="value" 页面。 Vue中的Render函数中有一个参数,这个参数是一个函数通常我们叫做h。...当我们重新切换回来时依旧会重新渲染(确实找不到对应的dom元素),但是之前的vue实例没有被销毁,vue实例中的属性和变量都还在,这个标签非常适合做单页面应用。 所有组件都有完整的生命周期。...计算属性和自定义方法的区别 methods方法和computed计算属性,两种方式的最终结果确实是完全相同; 不同的是计算属性是基于它们的响应式依赖进行缓存的。

    8.5K30

    16 个优秀的 Vue 开源项目

    还有一个内置的调试工具栏,可以帮助开发人员监视性能、路由、数据库查询和调试内部系统事件、扩展甚至可以添加自己的功能。另外,也可以使用CLI执行系统更新、安装和卸载扩展和主题,以及直接从终端清除缓存。...05 Gridsome Gridsome 与VuePress有许多相似之处,但它采用了一种不同的非常强大的方法来处理数据源。...它允许你连接并使用应用中的许多不同类型的数据,然后将这些数据统一到一个GraphQL 层中。基本上,Gridsome 的前端功能用Vue,数据管理用GraphQL 。...CSS(页面级)。...特点: ·熟悉且易于设置的基于模板的验证; ·i18n支持和错误消息在40+地区; ·异步和自定义规则支持; ·用TypeScript编写; ·没有依赖。

    4.4K20

    vue前端面试题2022_前端常见面试题

    组件通信 父组件向子组件通信 子组件通过 props 属性,绑定父组件数据,实现双方通信。 子组件向父组件通信 将父组件的事件在子组件中通过 $emit 触发。...Vue 中怎么自定义指令 全局注册 // 注册一个全局自定义指令 `v-focus` Vue.directive('focus', { // 当被绑定的元素插入到 DOM 中时……...Vue 中怎么自定义过滤器 可以用全局方法 Vue.filter() 注册一个自定义过滤器,它接收两个参数:过滤器 ID 和过滤器函数。过滤器函数以值为参数,返回转换后的值。...Vue 中 key 的作用 key 的特殊属性主要用在 Vue 的虚拟 DOM 算法,在新旧 nodes 对比时辨识 VNodes。...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

    1.9K10

    纯前端控件集 WijmoJS 2018V2发布,在React、Vue和Angular中更易用

    除在全球率先支持 AngularJS外,现已全面应用于 React、Vuejs、TypeScript 、Ionic 等主流框架中。...WijmoJS 现在拥有了用于创建和自定义前端控件的设计器,包含两个beta版本,一个是与Visual Studio Code完美融合的设计器、另一个则是在线Web设计器,提供实时预览和编辑页面属性的功能...Web在线设计器 此设计器是用于创建和自定义WijmoJS控件的Web应用程序。 开发人员可以在任何浏览器中运行此设计器。它允许将控件添加到设计图面,然后根据自己的喜好自定义它们。...WijmoJS Web组件允许用户以声明方式将WijmoJS控件添加到HTML页面,并将其作为常用DOM元素进行操作,而无需使用任何其他框架。...随着新版本上线,WijmoJS 添加了Web Components In Angular示例,演示了如何在Angular应用程序中使用 WijmoJS Web组件。

    7K20

    总结19道出现率高达98.9%的Vuejs面试题

    组件通信 父组件向子组件通信 子组件通过 props 属性,绑定父组件数据,实现双方通信。 子组件向父组件通信 将父组件的事件在子组件中通过 $emit 触发。...Vue 中怎么自定义指令 全局注册 // 注册一个全局自定义指令 `v-focus` Vue.directive('focus', { // 当被绑定的元素插入到 DOM 中时…… inserted...(https://cn.vuejs.org/v2/guide/custom-directive.html)。...Vue 中怎么自定义过滤器 可以用全局方法 Vue.filter() 注册一个自定义过滤器,它接收两个参数:过滤器 ID 和过滤器函数。过滤器函数以值为参数,返回转换后的值。...Vue 中 key 的作用 key 的特殊属性主要用在 Vue 的虚拟 DOM 算法,在新旧 nodes 对比时辨识 VNodes。

    3.2K20

    在业务代码中常用到的Vue数据通信方式

    ​​ 在vue中数据流是单向的,通常父子组件通信props或者自定义事件,或者还有provide/inject,甚至借助第三方数据流方案vuex,在通常的项目中我们会高频用到哪些通信方案?...我们先看下在vue中我能想到的数据通信方案 1、props父传子 2、自定义事件@event="query" 3、.sync修饰符 3、vuex跨组件通信 4、Vue.observable 5、provide...自定义事件emit通信 ......*/ new Vue({ el: '#app', store, router, components: { App }, template: '' }) 我们看下主页面路由页面...provide / inject 这是一个父组件可以向子孙组件透传数据的一个属性,也就是意味着在所有子孙组件,能拿到父组件provide提供的数据,具体可以看下下面例子 <div

    5.1K50

    「vue基础」Vue Router 使用指南上篇(文末送漂亮的 Vue 站点源码)

    router.js 的文件,然后添加以下内容: src/router.js ?...从上述代码中,我们可以看出,我们将导入的 router.js 创建的实例作为参数传递给Vue实例,然后作为插件注册到我们的Vue实例中,这样使得路由功能在整个项目中得以使用。...除了这些参数,还有如下常见参数,你需要了解下: name: 这个属性是可选项,如果你的程序比较简单,就没必要使用,但是大多数我还是建议你配置上,比如你可以在如下场景进行使用: 1、通过name属性,为一个页面中不同的...meta:我们可以通过这个参数自定义些内容,比如我们做导航的面包屑路径问题,将会用到这个配置,如下图所示: ? ? ?...上述代码我们指定了路由的名称name,并指定 /blog/slug 这种路径的传参形式,接下来我们来看看如何在路由里接收获取这个参数,比如下段代码,我们接收这个参数进行AJAX的接口请求,如下所示: ?

    1.1K40
    领券