AngularJS学习第一天:登录功能

angular是什么??

查看 angular简介请访问:点此处访问

怎么下载源文件

下载地址:点击下载

怎么讲?

我打算以实例为导向,讲解各个指令,最后合并所有,做出来一个简单的单页面应用

今天的实例是一个简单的登录功能

先看看运行效果

QQ截图20160923111404.png

接下来开始

准备结构

//页面头部设置
<!DOCTYPE html>
<html>
<meta charset="utf-8">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta http-equiv="Expires" content="0" />
<meta content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" name="viewport">
<head>
    <title>第一个angular页面</title>

//body 部分代码
<div>
  <div >
    <h1>登录</h1>
    <form>
    <p><input type="text"  placeholder="用户名"/></p>
    <p><input type="password"  placeholder="密码"/></p>
    <p><input type="button"  value="登录" /></p>
  </form>
  <div class="text">
  <p>你输入的用户名:</p>
  <p>密码:</p>
</div>
</div>

样式


<style>
      *{
        padding:0px;
        margin:0px;
        font-size:10px;
        font-family:Arial, 'Microsoft YaHei', Helvetica, 'Hiragino Sans GB';
      }
      input{
        font-size:1.4rem;
        border:1px solid #ededed;
        padding:5px 10px;
        width:100%;
        box-sizing:border-box;
      }
      form{
        padding:20px 10px;
      }
      h1{
        font-size:1.8rem;
        text-align:center;
        padding:30px;
        color:#ff4354;
      }
      form p{
        padding:5px 0px;
      }
      form input[type=button]{
        padding:10px 0px;
        border:1px solid #ff4354;
        background-color: #ff4354;
        color: #ffffff;
        border-radius: 5px;
      }
      .text p{
        font-size: 1.4rem;
        padding: 5px 10px;
      }
    </style>

引入 angularJS

<script src="angular-1.3.0.js"></script>

告诉 angular 他的作用域是什么
什么是作用域?就是告诉它,让它只在某个区域起作用
怎么告诉? 用指令 ng-app

 <!--示例代码-->
  <div ng-app="" ng-init="text='World'">
      <div>angular运行的时候会编译这部分</div>
       <div>Hello {{text}}</div>
  </div>
  <div class="ignore">
   angular不会管这部分Hello {{text}}
  </div>  

 <!--运行结果-->
<div ng-app="" ng-init="text='World'" class="ng-scope">
      <div>angular运行的时候会编译这部分</div>
       <div class="ng-binding">Hello World</div>
  </div>
<div  class="ignore">
   angular不会管这部分Hello {{text}}
</div>

//说明:
1. ng-app功能: 告诉angular 它的作用域
2. ng-app作用域: 都知道div是双标签,很明显 ng-app 的作用域从节点开始到节点结束,.ignore 没在ng-app 里面所以angular 不管
3、ng-app  适用标签, html div p 等等都是可以的,因为我们有时候需要整个页面都被angular编译,有时候只是需要局部是
4、ng-init 功能  定义这个作用域里面初始时候的数据 例如例子中 初始的时候设置 *text='World'*,就是在作用域里面定义了一个变量text值得World
5、怎么调用变量?  用插件表达式来调用,实例见上边代码  {{text}},即双大括号里面写入变量名。
6、我想在变量前面加上某个字符串怎么办?你可以这么写 {{"嘿嘿"+text}};这么写 {{1+2}} ;  这不就是js表达式吗? Binggo !!!
7、还有另外一种调用方式,不过这种调用方式依赖标签,如【即ng-bind 指令 的 =号后面写上要绑定的变量名】
<span ng-bind="text"></span>

那么我们现在就告诉angular他的作用域
代码如下

<div ng-app="">
  <div >
    <h1>登录</h1>
    <form>
    <p><input type="text"  placeholder="用户名"/></p>
    <p><input type="password"  placeholder="密码"/></p>
    <p><input type="button"  value="登录" /></p>
  </form>
  <div class="text">
  <p>你输入的用户名:</p>
  <p>密码:</p>
</div>
</div>

既然页面已经做好了,我们就来处理用户的输入,完成功能吧
代码如下:

<div ng-app="">
<div ng-controller="myFirstCtrl">
  <h1>登录</h1>
  <form>
  <p><input type="text" ng-model="username" placeholder="用户名"/></p>
  <p><input type="password" ng-model="userpwd" placeholder="密码"/></p>
  <p><input type="button" ng-click="login()" value="登录" /></p>
</form>
<div class="text">
<p>你输入的用户名:{{username}}</p>
<p>密码:{{userpwd}}</p>
</div>
</div>

相关 JS
<script>
        function myFirstCtrl($scope){
            $scope.username="";
            $scope.userpwd="";
            $scope.login=function(){
                if($scope.username==""||$scope.userpwd==""){
                    alert("信息未输入完整");
                }else{
                    console.log("去登陆");
                }
           }
        }
    </script>

//说明
1、ng-controller 是做什么? ng-controller 是控制的某个作用域部分的
2、他跟ng-app什么关系?    ng-app是控制整个app的,整个app可以由多个ng-controller组成
3、怎么创建一个控制器?  写一个 function 即可 函数名就是控制器名
4、$scope是个什么鬼?     $scope是作用域对象
5、$scope做什么用?   你还记得 ng-init中定义的 text 变量吗?它实际上就是定义在$scope底下,
这样控制器的作用域里面就可以通过插件表达式调用到它,
实际上就相当于  $scope.text="World";
6、$scope 下边可以写方法吗? 当然可以,你直接就像平常写js哪样,直接给$scope这个对象属性赋值为函数即可
            $scope.func=function(){
                    console.log("我是个函数");
           }
7、定义函数我怎么调用啊?  用事件绑定指令!ng-[我是事件名字]
实例:给元素增加单击事件
ng-click="func()"

8、ng-model 是啥? 这个指令告诉Angular 等号后边的这个变量需要双向同步
9、什么是双向同步? 我的理解是你再输入框里面输入的时候,
你输入什么angular就把这个值取到更新到$scope的对应属性上去;同样你再程序里面改动这个属性的时候也会直接反映到页面上。

OK 大功告成!!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343

推荐阅读更多精彩内容