uniapp 学习

uni-app介绍

 

 

 

下载微信开发者工具

 

运行uniapp    在浏览器中运行  

 

 

 HBuilder中   工具-设置-运行设置   配置微信开发者工具安装目录

 

 微信开发者工具  设置-安全设置-开启服务端口

 

 

 真机运行????


 

uniapp配置文件   pages.json

 1 {
 2     "pages": [ //pages数组中第一项表示应用启动页,参考:https://uniapp.dcloud.io/collocation/pages
 3         {
 4             "path": "pages/index/index",
 5             "style": {
 6                 "navigationBarTitleText": "test",
 7                 "h5":{
 8                     "titleNView":{
 9                         "backgroundColor":"#000000",
10                         "titleColor":"#fff",
11                         "titleText":"h5"
12                     }
13                 }
14             }
15         }, {
16             "path": "pages/message/message",
17             "style": {
18                 "navigationBarTitleText": "message页面", //导航栏标题文字内容
19                 "h5": { //H5平台配置
20                     "titleNView": {
21                         "backgroundColor": "#4CD964",
22                         "titleColor": "#cc5639"
23                     },
24                     "pullToRefresh": {
25                         "color": "#f00"
26                     }
27                 }
28             }
29         }, {
30             "path": "pages/switch/switch",
31             "style": {
32                 "navigationBarTitleText": "switch"
33             }
34         }
35         ,{
36             "path" : "pages/me/me",
37             "style" : {}
38         }
39     ],
40     "globalStyle": {
41         "navigationBarTextStyle": "white", //导航栏标题颜色及状态栏前景颜色,仅支持 black/white
42         "navigationBarTitleText": "我的学习", //导航栏标题文字内容
43         "navigationBarBackgroundColor": "#fc1", //导航栏背景颜色(同状态栏背景色)
44         "enablePullDownRefresh": true, //是否开启下拉刷新
45         "backgroundColor": "#f00", //下拉显示出来的窗口的背景色
46         "backgroundTextStyle": "light" //下拉 loading 的样式,仅支持 dark / light
47     },
48     "condition": { //模式配置,仅开发期间生效
49         "current": 0, //当前激活的模式(list 的索引项)
50         "list": [{
51                 "name": "index", //模式名称
52                 "path": "pages/index/index", //启动页面,必选
53                 "query": "interval=4000&autoplay=false" //启动参数,在页面的onLoad函数里面得到。
54             },
55             {
56                 "name": "message", //模式名称
57                 "path": "pages/message/message", //启动页面,必选
58                 "query": "interval=4000&autoplay=false" //启动参数,在页面的onLoad函数里面得到。
59             },
60             {
61                 "name": "switch",
62                 "path": "pages/switch/switch"
63             }
64         ]
65     },
66     "tabBar": {
67         "color": "#7A7E83",
68         "selectedColor": "#000000",
69         "borderStyle": "black",
70         "backgroundColor": "#ffffff",
71         "list": [{
72                 "pagePath": "pages/index/index",
73                 "iconPath": "static/tabbar/one.png",
74                 "selectedIconPath": "static/tabbar/one_active.png",
75                 "text": "首页"
76             }, {
77                 "pagePath": "pages/message/message",
78                 "iconPath": "static/tabbar/two.png",
79                 "selectedIconPath": "static/tabbar/two_active.png",
80                 "text": "发现"
81             },
82             {
83                 "pagePath": "pages/switch/switch",
84                 "iconPath": "static/tabbar/three.png",
85                 "selectedIconPath": "static/tabbar/three_active.png",
86                 "text": "信息"
87             },
88             {
89                 "pagePath": "pages/me/me",
90                 "iconPath": "static/tabbar/four.png",
91                 "selectedIconPath": "static/tabbar/four_active.png",
92                 "text": "我的"
93             }
94         ]
95     }
96 
97 }

 


 

 

css引入静态资源

/* 绝对路径 */

@import url('/common/uni.css');

@import url('@/common/uni.css');

/* 相对路径 */

@import url('../../common/uni.css');

定义在 App.vue 中的样式为全局样式,作用于每一个页面。

在 pages 目录下 的 vue 文件中定义的样式为局部样式,只作用在对应的页面,并会覆盖 App.vue 中相同的选择器。

uni-app 支持使用字体图标,使用方式与普通 web 项目相同

字体文件的引用路径推荐使用以 ~@ 开头的绝对路径。

 @font-face {
     font-family: test1-icon;
     src: url('~@/static/iconfont.ttf');
 }

使用scss

uni.scss定义全局样色变量  在页面中引用    安装scss插件 工具->插件安装->scss/sass编译

uni.scss

/* 颜色变量 */
$red:#00ff55;

页面中

<style lang="scss">
.box{
width: 100px;
height: 100px;
border: 1px solid red;
text{
color: $red
}
}
</style>

 


 图片裁剪、缩放的模式    两种常用

 mode="aspectFill"   相当于 background-size:cover     

aspectFill 缩放模式,保持纵横比缩放图片,只保证图片的短边能完全显示出来。也就是说,图片通常只在水平或垂直方向是完整的,另一个方向将会发生截取。
widthFix 缩放模式,宽度不变,高度自动变化,保持原图宽高比不变

vue语法

v-if   

 

 当判断条件为true时显示内容

 

v-for

v-for 指令基于一个数组来渲染一个列表。v-for 指令需要使用 item in items 形式的特殊语法,其中 items 是源数据数组,而 item 则是被迭代的数组元素的别名。

<ul id="example-1">
  <li v-for="item in items" :key="item.message">
    {{ item.message }}
  </li>
</ul>


var example1 = new Vue({
  el: '#example-1',
  data: {
    items: [
      { message: 'Foo' },
      { message: 'Bar' }
    ]
  }
})

 

在 v-for 块中,我们可以访问所有父作用域的 property。v-for 还支持一个可选的第二个参数,即当前项的索引。

 

 

 

 

 

 

 

在data中定义对象
data:{
    user:{
     id:1,
     name:'托尼.贾',
     gender:'男'
   }
}


在html中使用 v-for 指令渲染


<p v-for="(val,key) in user">--键是--{{key}}--值是--{{val}}</p>

 

迭代数字
<!-- 注意:如果使用v-for迭代数字的话,前面 count 的值从 1 开始-->
<p v-for="count in 10">这是第{{count}}次循环</p>

 

 

v-if

 

 

v-bind: src=""    简写  :src=“”     属性绑定

 v-on:click=“”         简写  @click=   事件绑定

 

有时也需要在内联语句处理器中访问原始的 DOM 事件。可以用特殊变量 $event 把它传入方法

<button type="default" @click="warn(300,'hedan', $event)" >点击传递参数 </button>

 

 

在事件处理程序中调用 event.preventDefault() 或 event.stopPropagation() 是非常常见的需求。尽管我们可以在方法中轻松实现这点,但更好的方式是:方法只有纯粹的数据逻辑,而不是去处理 DOM 事件细节。

为了解决这个问题,Vue.js 为 v-on 提供了事件修饰符。之前提过,修饰符是由点开头的指令后缀来表示的。

  • .stop
  • .prevent
  • .capture
  • .self
  • .once
  • .passive

 


 

 

posted @ 2020-09-04 14:38  青幽草  阅读(309)  评论(0编辑  收藏  举报