1.登录页

weexpack  Login.vue

<!-- 登录页 -->
<template>
<div class="wrapper">
<div class="login">
<div class="input-wrapper">
<input v-model="userNumber" class="input" type="text" placeholder="账号" autofocus="true" value=""/>
<image class="input-img" src="http://cdn-img.easyicon.net/png/11741/1174195.gif"></image>
</div>
<div class="input-wrapper">
<input v-model="userPassword" class="input" type="password" placeholder="密码" value=""/>
<image class="input-img" src="http://cdn-img.easyicon.net/png/11741/1174192.gif"></image>
</div>
<div class="input-wrapper">
<div class="input-login" @click="login">
<text class="input-login-text">登录</text>
</div>
</div>
<div class="input-wrapper">
<text class="input-forget" @click="findPassword">找回密码</text>
<text class="input-register" @click="register">立即注册</text>
</div>
</div>
</div>
</template> <script>
// 弹窗
const modal = weex.requireModule('modal'); module.exports = {
data(){
return{
userNumber:'',
userPassword:''
}
},
created () {
//
},
methods:{
/*找回密码*/
findPassword() {
modal.toast({
'message': '找回密码暂时未开发',
'duration': 1
});
},
/*注册*/
register() {
modal.toast({
'message': '注册暂时未开发',
'duration': 1
});
},
/*处理登录*/
login() {
if(!this.userNumber){
modal.toast({
'message': '请输入手机号',
'duration': 1
});
return;
}else if(!this.userPassword.length){
modal.toast({
'message': '请输入密码',
'duration': 1
});
return;
}
// 登录成功
modal.toast({
'message': '登录成功',
'duration': 1
});
}
}
}
</script> <style scoped>
/*整体框架 绝对定位*/
.wrapper {
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
}
.login{
width: 600px;
height: 500px;
/*垂直水平居中*/
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
margin: auto;
}
.input-wrapper{
width: 600px;
margin-bottom: 30px;
}
.input {
font-size: 30px;
height: 80px;
width: 600px;
padding-left: 90px;
padding-top: 15px;
padding-bottom: 15px;
border-width:1px;
border-color: #48c9bf;
border-radius:10px;
outline: none;
}
.input-img{
position: absolute;
top:10px;
left: 15px;
width: 60px;
height: 60px;
}
.input-login{
height: 80px;
width: 600px;
background-color: #48c9bf;
border-radius: 10px;
margin-top: 40px;
}
.input-login-text{
height: 80px;
width: 600px;
text-align: center;
line-height: 80px;
color: white;
font-size: 35px;
}
.input-forget{
position: absolute;
left: 20px;
font-size: 30px;
}
.input-register{
position: absolute;
right: 20px;
font-size: 30px;
}
</style>

注:style上需要添加 scoped,否则无法自动适配。

vue  Login.vue

<!-- 登录页 -->
<template>
<div class="login">
<!-- 输入框 -->
<div class="input-wrapper">
<input v-model="userNumber" class="input" type="text" placeholder="账号" autofocus="true" value=""/>
<img class="input-img" src="" />
</div>
<div class="input-wrapper">
<input v-model="userPassword" class="input" type="password" placeholder="密码" value=""/>
<img class="input-img" src="" />
</div>
<!-- 登录按钮 -->
<div class="input-wrapper">
<div class="input-login" @click="login">登录</div>
</div>
<!-- 其他操作 -->
<div class="input-wrapper">
<span class="input-forget" @click="findPassword">找回密码</span>
<span class="input-register" @click="register">立即注册</span>
</div>
</div>
</template> <script>
export default {
name:'Login',
data(){
return{
userNumber:'',
userPassword:''
}
},
mounted () {
// 隐藏tab栏
this.$store.dispatch('hideTabBar');
},
methods:{
/*找回密码*/
findPassword() {
this.$toast.center('找回密码暂时未开发');
},
/*注册*/
register() {
this.$toast.center('注册暂时未开发');
},
/*处理登录*/
login() {
if(!this.userNumber){
this.$toast.center('请输入手机号');
return;
}else if(!this.userPassword){
this.$toast.center('请输入密码');
return;
}
/*登录成功*/
this.$toast.center('登录成功!');
// 跳转home
this.$router.push({path:'/'});
}
}
}
</script> <style scoped>
.login{
width: 100%;
height: 200px;
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
margin: auto;
}
.input-wrapper{
width: 90%;
margin: 0px auto 30px;
position: relative;
}
.input {
font-size: 16px;
height: 44px;
width: 100%;
border-width:1px;
border-style: solid;
border-color: #48c9bf;
border-radius:5px;
outline: none;
text-indent:2.5em;
}
.input-img{
position: absolute;
top:6px;
left: 5px;
width: 30px;
height: 30px;
}
.input-login{
height: 44px;
line-height: 44px;
width: 100%;
background-color: #48c9bf;
border-radius: 6px;
color: white;
font-size: 16px;
text-align: center;
}
.input-forget{
position: absolute;
left: 0px;
font-size: 16px;
}
.input-register{
position: absolute;
right: 0px;
font-size: 16px;
}
</style>

  

2.效果图

weexpack 的 Login.vue 及 vue 的 Login.vue的更多相关文章

  1. Vue系列之 => webpack结合vue使用

    安装 npm i vue -S ,  在html页面中放一个容器绑定到el上. 修改webpack.config.js , 在与entry , output节点平级加上 resolve 节点. res ...

  2. 从零开始学 Web 之 Vue.js(六)Vue的组件

    大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...

  3. vue聊天室|h5+vue仿微信聊天界面|vue仿微信

    一.项目简介 基于Vue2.0+Vuex+vue-router+webpack2.0+es6+vuePhotoPreview+wcPop等技术架构开发的仿微信界面聊天室——vueChatRoom,实现 ...

  4. vue前端开发那些事——vue开发遇到的问题

    vue web开发并不是孤立的.它需要众多插件的配合以及其它js框架的支持.本篇想把vue web开发的一些问题,拿出来讨论下.  1.web界面采用哪个UI框架?项目中引用了layui框架.引入框架 ...

  5. Vue 全家桶,深入Vue 的世界

    内容简介: Vue 实例上的属性 Vue 生命周期 Vue 数据绑定 computed 计算属性 watch 监听器 Vue 组件 Vue 组件 extend Vue 组件高级属性 Vue 的rend ...

  6. Vue 开发技巧或者说Vue知识点梳理(转,自个学习)

    Vue 组件通讯 ——常见使用场景可以分为三类: 父子通信: 父向子传递数据是通过 props,子向父是通过 events($emit):通过父链 / 子链也可以通信($parent / $child ...

  7. Vue.js 第1章 Vue常用指令学习

    今日目标 能够写出第一个vue应用程序 能够接受为什么需要学vue 能够使用指令 能够通过指定完成简单的业务(增加删除查询) 能够理解mvvm 为什么要学习vue 企业需要 可以提高开发效率 实现vu ...

  8. vue新手入门之使用vue框架搭建用户登录注册案例,手动搭建webpack+Vue项目(附源码,图文详解,亲测有效)

    前言 本篇随笔主要写了手动搭建一个webpack+Vue项目,掌握相关loader的安装与使用,包括css-loader.style-loader.vue-loader.url-loader.sass ...

  9. 实例PK(Vue服务端渲染 VS Vue浏览器端渲染)

    Vue 2.0 开始支持服务端渲染的功能,所以本文章也是基于vue 2.0以上版本.网上对于服务端渲染的资料还是比较少,最经典的莫过于Vue作者尤雨溪大神的 vue-hacker-news.本人在公司 ...

  10. Vue服务端渲染和Vue浏览器端渲染的性能对比

    Vue 2.0 开始支持服务端渲染的功能,所以本文章也是基于vue 2.0以上版本.网上对于服务端渲染的资料还是比较少,最经典的莫过于Vue作者尤雨溪大神的 vue-hacker-news.本人在公司 ...

随机推荐

  1. python中实现格式化输出 %用法

    当我们在python中需要打印出特定格式的内容时可以用到这个方法,方法介绍如下: 例如我们现在要收集用户的一些个人信息,这时候我们的代码如下: name=input("name: " ...

  2. win10系统中virtualbox无法安装64位系统

    win10系统中virtualbox无法安装64位系统 先总结下如果想在虚拟机中安装64位的Linux系统,最好能满足这几个条件: 64位CPU 64位操作系统 64位的虚拟机软件 开启BIOS虚拟化 ...

  3. java 罕见的依赖报错 jstat: error while loading shared libraries: libjli.so: cannot open shared object file: No such file or directory

    java 都用了N长时间了,突然,意外地发现有一个依赖的so文件从来没找见过 # ldd /usr/bin/java linux-vdso.so.1 =>  (0x00007fffba76900 ...

  4. PYDay5- 数据类型set、三元运算、函数

    1.set set集合,是一个无序且不重复的元素集合 class set(object): """ set() -> new empty set object se ...

  5. luogu4301 [CQOI2013]新Nim游戏

    nim和线性基 #include <algorithm> #include <iostream> #include <cstdio> using namespace ...

  6. Brownie Slicing(二分枚举答案)

    描述 Bessie has baked a rectangular brownie that can be thought of as an RxC grid (1 <= R <= 500 ...

  7. 82. Spring Boot – 启动彩蛋【从零开始学Spring Boot】

    我们在[28. SpringBoot启动时的Banner设置 ] 这一小节介绍过设置Spring Boot的Banner,但是实际当中,我们希望做的更漂亮,所以也就有了这小节Spring Boot-启 ...

  8. BZOJ 2154 Crash的数字表格 ——莫比乌斯反演

    求$\sum_{i=1}^n\sum_{j=1}^n lcm(i,j)$ 枚举因数 $ans=\sum_{d<=n} F(d) * d$ $F(d)$表示给定范围内两两$\sum_{gcd(i, ...

  9. BZOJ 4004 [JLOI2015]装备购买 ——线性基

    [题目分析] 题目很简单,就是要维护一个实数域上的线性基. 仿照异或空间的线性基的方法,排序之后每次加入一个数即可. 卡精度,开long double 和 1e-6就轻松水过了. [代码] #incl ...

  10. [BZOJ1595] [Usaco2008 Jan]人工湖(单调栈)

    传送门 好难的题..至少对我来说. 这题就是模拟从最低的平台注水,然后将最低的填满以后从最低的平台向两边扩展,每次找最近的最低的平台h,然后将水填到h高度. 栈里存的是向外扩展的时候,有时会遇到高度递 ...