Material Design是什么?

https://www.zhihu.com/topic/20005114/top-answers

我们挑战自我,为用户创造了崭新的视觉设计语言。与此同时,新的设计语言除了遵循经典设计定则,还汲取了最新的科技,秉承了创新的设计理念。这就是原质化设计(Material Design)。这份文档是动态更新的,将会随着我们对 Material Design 的探索而不断迭代、升级。

Vue Material

https://vuematerial.io/

https://vuematerial.io/getting-started/

Introduction

Vue Material is the best integration between Vue.js and Material Design specs! You can easily configure it to suit all your needs through an easy API.

The documentation is divided by Themes, Components and UI Elements. The themes area is the definitive guide on how to theme your application (or write your own themes). The Components and UI Elements parts shows live examples, along with an API Table of each component/resource.

脚手架

https://github.com/vuematerial/webpack

vue-webpack-boilerplate

A full-featured Webpack setup + VueMaterial with hot-reload, lint-on-save, unit testing & css extraction.

This is a project template for vue-cli. It is recommended to use npm 3+ for a more efficient dependency tree.

$ npm install -g vue-cli
$ vue init vuematerial/webpack my-project
$ cd my-project
$ npm install
$ npm run dev

安装遇到的问题

https://blog.csdn.net/seekertime/article/details/68944482

鉴于国内的环境,node-sass实在是太难安装了,可以直接通过淘宝的npm镜像来安装。

1.安装cnpm(https://npm.taobao.org/)
npm install -g cnpm --registry=https://registry.npm.taobao.org

2.在项目文件夹下安装node-sass
cnpm install --save-dev node-sass
说明:--save-dev自动将node-sass加入到项目文件夹下的package.json中

https://github.com/sass/node-sass

Install from mirror in China

npm install -g mirror-config-china --registry=http://registry.npm.taobao.org
npm install node-sass

示例

https://github.com/fanqingsong/code-snippet/tree/master/web/materialdesign_quickstart

<template>
<div class="centered-container">
<md-content class="md-elevation-3"> <div class="title">
<img src="https://vuematerial.io/assets/logo-color.png">
<div class="md-title">Vue Material</div>
<div class="md-body-1">Build beautiful apps with Material Design and Vue.js</div>
</div> <div class="form">
<md-field>
<label>E-mail</label>
<md-input v-model="login.email" autofocus></md-input>
</md-field> <md-field md-has-password>
<label>Password</label>
<md-input v-model="login.password" type="password"></md-input>
</md-field>
</div> <div class="actions md-layout md-alignment-center-space-between">
<a href="/resetpassword">Reset password</a>
<md-button class="md-raised md-primary" @click="auth">Log in</md-button>
</div> <div class="loading-overlay" v-if="loading">
<md-progress-spinner md-mode="indeterminate" :md-stroke="2"></md-progress-spinner>
</div> </md-content>
<div class="background" />
</div>
</template> <script>
export default {
name: "App",
data() {
return {
loading: false,
login: {
email: "",
password: ""
}
};
},
methods: {
auth() {
// your code to login user
// this is only for example of loading
this.loading = true;
setTimeout(() => {
this.loading = false;
}, 5000);
}
}
};
</script> <style lang="scss">
.centered-container {
display: flex;
align-items: center;
justify-content: center;
position: relative;
height: 100vh;
.title {
text-align: center;
margin-bottom: 30px;
img {
margin-bottom: 16px;
max-width: 80px;
}
}
.actions {
.md-button {
margin: 0;
}
}
.form {
margin-bottom: 60px;
}
.background {
background: url(data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" width="1920" height="1080">
  <path fill="#f3f3f3" stroke="#f3f3f3" stroke-width="1.51" d="M144-496l627 167 259 6z"/>
  <path fill="#e3e3e3" stroke="#e3e3e3" stroke-width="1.51" d="M473 1526l-710 144 1549-64z"/>
  <path fill="#eee" stroke="#eee" stroke-width="1.51" d="M1030-323h591l383-159z"/>
  <path fill="#f1f1f1" stroke="#f1f1f1" stroke-width="1.51" d="M144-496l886 173 974-159z"/>
  <path fill="#e0e0e0" stroke="#e0e0e0" stroke-width="1.51" d="M2231 495l-62 205 104 312z"/>
  <path fill="#e6e6e6" stroke="#e6e6e6" stroke-width="1.51" d="M1978-42l253 537 61-745z"/>
  <path fill="#efefef" stroke="#efefef" stroke-width="1.51" d="M144-496l1860 14 534-92z"/>
  <path fill="#f5f5f5" stroke="#f5f5f5" stroke-width="1.51" d="M-598-561l742 65 2394-78z"/>
  <path fill="#e0e0e0" stroke="#e0e0e0" stroke-width="1.51" d="M2273 1012l-19 449 284-2035z"/>
  <path fill="#eaeaea" stroke="#eaeaea" stroke-width="1.51" d="M2004-482l288 232 246-324z"/>
  <path fill="#e6e6e6" stroke="#e6e6e6" stroke-width="1.51" d="M2292-250l-61 745 307-1069z"/>
  <path fill="#e3e3e3" stroke="#e3e3e3" stroke-width="1.51" d="M2231 495l42 517 265-1586z"/>
  <path fill="#ddd" stroke="#ddd" stroke-width="1.51" d="M1849 1003l-103 412 229 141z"/>
  <path fill="#e4e4e4" stroke="#e4e4e4" stroke-width="1.51" d="M1978-42l-93 530 346 7z"/>
  <path fill="#dcdcdc" stroke="#dcdcdc" stroke-width="1.51" d="M1849 1003l126 553 279-95z"/>
  <path fill="#ddd" stroke="#ddd" stroke-width="1.51" d="M1849 1003l405 458 19-449z"/>
  <path fill="#dfdfdf" stroke="#dfdfdf" stroke-width="1.51" d="M2169 700l-320 303 424 9z"/>
  <path fill="#eaeaea" stroke="#eaeaea" stroke-width="1.51" d="M2004-482l-26 440 314-208z"/>
  <path fill="#e2e2e2" stroke="#e2e2e2" stroke-width="1.51" d="M1885 488l284 212 62-205z"/>
  <path fill="#e2e2e2" stroke="#e2e2e2" stroke-width="1.51" d="M1885 488l-83 133 367 79z"/>
  <path fill="#e1e1e1" stroke="#e1e1e1" stroke-width="1.51" d="M1802 621l47 382 320-303z"/>
  <path fill="#dfdfdf" stroke="#dfdfdf" stroke-width="1.51" d="M1685 1139l61 276 103-412z"/>
  <path fill="#e2e2e2" stroke="#e2e2e2" stroke-width="1.51" d="M1802 621l-62 68 109 314z"/>
  <path fill="#dcdcdc" stroke="#dcdcdc" stroke-width="1.51" d="M1746 1415l-434 191 663-50z"/>
  <path fill="#e7e7e7" stroke="#e7e7e7" stroke-width="1.51" d="M1617 172l268 316 93-530z"/>
  <path fill="#ebebeb" stroke="#ebebeb" stroke-width="1.51" d="M1621-323l357 281 26-440z"/>
  <path fill="#eaeaea" stroke="#eaeaea" stroke-width="1.51" d="M1621-323l-4 495 361-214z"/>
  <path fill="#ebebeb" stroke="#ebebeb" stroke-width="1.51" d="M1410-49l207 221 4-495z"/>
  <path fill="#e5e5e5" stroke="#e5e5e5" stroke-width="1.51" d="M1617 172l185 449 83-133z"/>
  <path fill="#e5e5e5" stroke="#e5e5e5" stroke-width="1.51" d="M1617 172l123 517 62-68z"/>
  <path fill="#e1e1e1" stroke="#e1e1e1" stroke-width="1.51" d="M1740 689l-55 450 164-136z"/>
  <path fill="#e6e6e6" stroke="#e6e6e6" stroke-width="1.51" d="M1617 172l-393 451 516 66z"/>
  <path fill="#e2e2e2" stroke="#e2e2e2" stroke-width="1.51" d="M1244 962l441 177 55-450z"/>
  <path fill="#e5e5e5" stroke="#e5e5e5" stroke-width="1.51" d="M1224 623l20 339 496-273z"/>
  <path fill="#dfdfdf" stroke="#dfdfdf" stroke-width="1.51" d="M1685 1139l-373 467 434-191z"/>
  <path fill="#e1e1e1" stroke="#e1e1e1" stroke-width="1.51" d="M1244 962l68 644 373-467z"/>
  <path fill="#eaeaea" stroke="#eaeaea" stroke-width="1.51" d="M1410-49l-342 175 549 46z"/>
  <path fill="#e9e9e9" stroke="#e9e9e9" stroke-width="1.51" d="M1068 126l156 497 393-451z"/>
  <path fill="#ededed" stroke="#ededed" stroke-width="1.51" d="M1030-323l380 274 211-274z"/>
  <path fill="#eaeaea" stroke="#eaeaea" stroke-width="1.51" d="M1068 126l-79 82 235 415z"/>
  <path fill="#e4e4e4" stroke="#e4e4e4" stroke-width="1.51" d="M937 962l-185 409 492-409z"/>
  <path fill="#e2e2e2" stroke="#e2e2e2" stroke-width="1.51" d="M1244 962l-492 409 560 235z"/>
  <path fill="#ededed" stroke="#ededed" stroke-width="1.51" d="M1030-323l38 449 342-175z"/>
  <path fill="#e5e5e5" stroke="#e5e5e5" stroke-width="1.51" d="M1224 623L937 962h307z"/>
  <path fill="#e2e2e2" stroke="#e2e2e2" stroke-width="1.51" d="M752 1371l-279 155 839 80z"/>
  <path fill="#eaeaea" stroke="#eaeaea" stroke-width="1.51" d="M989 208L783 401l441 222z"/>
  <path fill="#e7e7e7" stroke="#e7e7e7" stroke-width="1.51" d="M748 789l189 173 287-339z"/>
  <path fill="#e9e9e9" stroke="#e9e9e9" stroke-width="1.51" d="M783 401l-35 388 476-166z"/>
  <path fill="#f0f0f0" stroke="#f0f0f0" stroke-width="1.51" d="M771-329l-12 454 271-448z"/>
  <path fill="#eee" stroke="#eee" stroke-width="1.51" d="M1030-323L759 125l309 1z"/>
  <path fill="#ececec" stroke="#ececec" stroke-width="1.51" d="M759 125l230 83 79-82z"/>
  <path fill="#e5e5e5" stroke="#e5e5e5" stroke-width="1.51" d="M481 1105l271 266 185-409z"/>
  <path fill="#ececec" stroke="#ececec" stroke-width="1.51" d="M759 125l24 276 206-193z"/>
  <path fill="#e7e7e7" stroke="#e7e7e7" stroke-width="1.51" d="M748 789l-267 316 456-143z"/>
  <path fill="#e8e8e8" stroke="#e8e8e8" stroke-width="1.51" d="M519 782l-38 323 267-316z"/>
  <path fill="#f1f1f1" stroke="#f1f1f1" stroke-width="1.51" d="M335-148l424 273 12-454z"/>
  <path fill="#f4f4f4" stroke="#f4f4f4" stroke-width="1.51" d="M172-428l163 280 436-181z"/>
  <path fill="#f6f6f6" stroke="#f6f6f6" stroke-width="1.51" d="M144-496l28 68 599 99z"/>
  <path fill="#eaeaea" stroke="#eaeaea" stroke-width="1.51" d="M519 782l229 7 35-388z"/>
  <path fill="#eee" stroke="#eee" stroke-width="1.51" d="M759 125L202 259l581 142z"/>
  <path fill="#ececec" stroke="#ececec" stroke-width="1.51" d="M202 259l317 523 264-381z"/>
  <path fill="#f0f0f0" stroke="#f0f0f0" stroke-width="1.51" d="M335-148L202 259l557-134z"/>
  <path fill="#e5e5e5" stroke="#e5e5e5" stroke-width="1.51" d="M481 1105l-8 421 279-155z"/>
  <path fill="#e8e8e8" stroke="#e8e8e8" stroke-width="1.51" d="M-179 1046l652 480 8-421z"/>
  <path fill="#ececec" stroke="#ececec" stroke-width="1.51" d="M-5 593l-174 453 660 59z"/>
  <path fill="#ebebeb" stroke="#ebebeb" stroke-width="1.51" d="M-5 593l486 512 38-323z"/>
  <path fill="#eee" stroke="#eee" stroke-width="1.51" d="M202 259L-5 593l524 189z"/>
  <path fill="#e8e8e8" stroke="#e8e8e8" stroke-width="1.51" d="M-179 1046l-58 624 710-144z"/>
  <path fill="#f3f3f3" stroke="#f3f3f3" stroke-width="1.51" d="M-109-23l311 282 133-407z"/>
  <path fill="#f5f5f5" stroke="#f5f5f5" stroke-width="1.51" d="M172-428L-109-23l444-125z"/>
  <path fill="#eee" stroke="#eee" stroke-width="1.51" d="M-245 772l66 274L-5 593z"/>
  <path fill="#f1f1f1" stroke="#f1f1f1" stroke-width="1.51" d="M-96 297l91 296 207-334z"/>
  <path fill="#f3f3f3" stroke="#f3f3f3" stroke-width="1.51" d="M-109-23l13 320 298-38z"/>
  <path fill="#f7f7f7" stroke="#f7f7f7" stroke-width="1.51" d="M144-496L-109-23l281-405z"/>
  <path fill="#f9f9f9" stroke="#f9f9f9" stroke-width="1.51" d="M-598-561l489 538 253-473z"/>
  <path fill="#ebebeb" stroke="#ebebeb" stroke-width="1.51" d="M-554 1392l317 278 58-624z"/>
  <path fill="#f4f4f4" stroke="#f4f4f4" stroke-width="1.51" d="M-109-23l-248 151 261 169z"/>
  <path fill="#f0f0f0" stroke="#f0f0f0" stroke-width="1.51" d="M-96 297l-149 475L-5 593z"/>
  <path fill="#ededed" stroke="#ededed" stroke-width="1.51" d="M-550 1181l-4 211 375-346z"/>
  <path fill="#f8f8f8" stroke="#f8f8f8" stroke-width="1.51" d="M-598-561l241 689 248-151z"/>
  <path fill="#f2f2f2" stroke="#f2f2f2" stroke-width="1.51" d="M-435 207l190 565 149-475z"/>
  <path fill="#f4f4f4" stroke="#f4f4f4" stroke-width="1.51" d="M-357 128l-78 79 339 90z"/>
  <path fill="#eee" stroke="#eee" stroke-width="1.51" d="M-245 772l-305 409 371-135z"/>
  <path fill="#f1f1f1" stroke="#f1f1f1" stroke-width="1.51" d="M-435 207l-115 974 305-409z"/>
  <path fill="#f8f8f8" stroke="#f8f8f8" stroke-width="1.51" d="M-598-561l163 768 78-79z"/>
  <path fill="#f5f5f5" stroke="#f5f5f5" stroke-width="1.51" d="M-598-561l48 1742 115-974z"/>
  <path fill="#f2f2f2" stroke="#f2f2f2" stroke-width="1.51" d="M-598-561l44 1953 4-211z"/>
</svg>
);
position: absolute;
height: 100%;
width: 100%;
top: 0;
bottom: 0;
right: 0;
left: 0;
z-index: 0;
}
.md-content {
z-index: 1;
padding: 40px;
width: 100%;
max-width: 400px;
position: relative;
}
.loading-overlay {
z-index: 10;
top: 0;
left: 0;
right: 0;
position: absolute;
width: 100%;
height: 100%;
background: rgba(255, 255, 255, 0.9);
display: flex;
align-items: center;
justify-content: center;
}
}
</style>

Vue Material的更多相关文章

  1. Vue开源项目库汇总

    最近做了一个Vue开源项目库汇总,里面集合了OpenDigg 上的优质的Vue开源项目库,方便移动开发人员便捷的找到自己需要的项目工具等,感兴趣的可以到GitHub上给个star. UI组件 elem ...

  2. Vue常用经典开源项目汇总参考-海量

    Vue常用经典开源项目汇总参考-海量 Vue是什么? Vue.js(读音 /vjuː/, 类似于 view) 是一套构建用户界面的 渐进式框架.与其他重量级框架不同的是,Vue 采用自底向上增量开发的 ...

  3. Vue常用开源项目汇总

    前言:Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架.与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用.Vue 的核心库只关注视图层,不仅易于上手,还 ...

  4. Vue应用框架整合与实战--Vue技术生态圈篇

    实用框架以及工具 UI组件 开发框架 实用库 服务端 辅助工具 应用实例 Demo示例 UI组件 Element-UI ★13489 - 饿了么出品的Vue2的web UI工具套件 Vux ★8133 ...

  5. vue各种插件汇总

    https://blog.csdn.net/wh8_2011/article/details/80497620(copy) Vue是什么? Vue.js(读音 /vjuː/, 类似于 view) 是一 ...

  6. Vue(二十七)当前GitHub上排名前十的热门Vue项目(转载)

    原文地址:https://my.oschina.net/liuyuantao/blog/1510726 1. ElemeFE/element tag:vue javascript components ...

  7. VUE插件大总结

    UI组件 element - 饿了么出品的Vue2的web UI工具套件 Vux - 基于Vue和WeUI的组件库 mint-ui - Vue 2的移动UI元素 iview - 基于 Vuejs 的开 ...

  8. Vue相关开源项目库汇总

    https://github.com/opendigg/awesome-github-vue http://www.opendigg.com/tags/front-vue README.md 内容 U ...

  9. vue插件大全汇总

    Vue是一个构建数据驱动的 web 界面的渐进式框架.Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件特别整理了常用的vue插件,来了个大汇总,方便查找使用,便于工作 ...

随机推荐

  1. 【Linux基础】查看硬件信息-内存和硬盘

     1.使用free命令查看内存使用 (1)内存总量大小:查看Mem中的total值3697M free -m total used free shared buffers cached -/+ buf ...

  2. HBase源码实战:ImportTsv

    /** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agr ...

  3. sklearn.linear_model.LogisticRegression参数说明

    目录 sklearn.linear_model.LogisticRegression sklearn.linear_model.LogisticRegressionCV sklearn.linear_ ...

  4. 将nginx永久加入到系统环境变量

    php,mysql的永久方法跟这个一样   下来配置环境变量 在/etc/profile 中加入: export NGINX_HOME=/usr/local/nginxexport PATH=$PAT ...

  5. php中一些容易混淆的函数总结

    在我们日常PHP开发中,经常会使用一些函数完成相关操作,但是有些函数功能相近,很容易混淆,再次总结一下 1. __DIR__  &&  getcwd() 看官方解释: getcwd: ...

  6. synchronized详解

    关于synchronized,本文从使用方法,底层原理和锁的升级优化这几个方面来介绍. 1.synchronized的使用: synchronized可以保证在同一时刻,只有一个线程可以操作共享变量, ...

  7. Eclipse 设置背景色

    window -> preferences ->  General -> Editors -> Test Editors -> Background color 勾掉Sy ...

  8. Python——编译标准

    注意事项 1.关于包相关的导入语句也分为import和from ... import ...两种,但是无论哪种,无论在什么位置,在导入时都必须遵循一个原则:凡是在导入时带点的,点的左边都必须是一个包, ...

  9. Socket通信例子

    Server端 using System; using System.Collections.Generic; using System.ComponentModel; using System.Da ...

  10. [模板] 最近公共祖先/lca

    简介 最近公共祖先 \(lca(a,b)\) 指的是a到根的路径和b到n的路径的深度最大的公共点. 定理. 以 \(r\) 为根的树上的路径 \((a,b) = (r,a) + (r,b) - 2 * ...