party_bid第一张卡片感悟总结(一)

        在初步学习完完angular js之后,开始尝试做party_bid的第一张卡片。这个项目用到了敏捷开发的故事卡,用到了angular js,用到了yeoman和rubymine,这些对我来是一个全新的领域,特此总结一下。

        party_bid来源于百老汇,是一个竞价游戏。游戏分为四个部分,创建活动——活动报名——组织竞价——竞价分析,最终从竞价者中选出竞价最低且不重复作为获胜者。

1.首先建立一个新的文件夹。我的文件夹名为party_bid,进入文件夹。在终端输入下面的代码。

 

mkdir party_bid //创建文件夹party_bid
cd party_bid  //进入文件夹

 

2.用yeoman在party_bid文件夹下面生成一个新的工程。接着上面的代码,输入下面的代码。我的工程名字叫party_bid。建议在网速比较好的地方生成,生成速度会比较快,也不容易出现error。

 

yo party_bid  //生成工程文件

提醒 Would you like to use Sass (with Compass)? (Y/n)   n

提醒 Would you like to include Bootstrap? (Y/n)   y

其余按Enter键。

 

3.工程文件生成后,在相应文件夹下用终端输入下面代码,启动服务器。至此,准备活动全部完成,可以正式开始编写程序。

 

grunt serve

 

 4.首先先要把要引用的所有css文件引入index中。

 

<link href="css/bootstrap.min.css" rel="stylesheet" media="screen">
<link href="css/font-awesome.min.css" rel="stylesheet" media="screen">
<link href="css/android.css" rel="stylesheet" media="screen">

 href是指定的路径,是css文件的位置;rel是relation。

其次还要引入相对应使用的全部js文件。如下:

 

<script src="bower_components/jquery/dist/jquery.js"></script>
<script src="bower_components/angular/angular.js"></script>
<script src="scripts/route.js"></script>
<script src="scripts/controllers/main.js"></script
 

 

5.接下来就是要配置路由器实现页面和控制器之间的联系。部分代码如下:

 

$routeProvider
     .when('/', {
          templateUrl: 'views/main.html',
          controller: 'MainCtrl'
      })
     .when('/create_activity', {
          templateUrl: 'views/create_activity.html',
          controller: 'CreateActivityCtrl'
      })
 我是通过在main.html页面判断是否活动列表中是否存在活动而进行页面的跳转是跳转到activity_list还是create_activity,但是main页面并没有展示内容。

 

6.需求要求点击按钮实现页面的跳转。我使用的方式的ng-click,在对应的控制器中实现方法。举个列子:从活动报名的页面点击返回按钮跳转到活动列表中。

 

<button class="btn btn-primary header-left" ng-click="go_list()">返回</button>
 
$scope.go_list = function () {
            $location.path('/activity_list')
        }
 

 

7. 在活动列表页面中要求活动排序按照活动创建的顺序输出。我在存储数据时存成数组的形式,这里只需要将数组reverse之后遍历输出就可以了。这里也使用了ng-repeat方法。在localStorage中的数据传到name中,list对name进行遍历后把结果输出。

 

<li ng-repeat='list in name'>  
            {{list}}    //输出遍历结果
 下面是在控制器中的代码。首先判断localStorage中是否有活动,如果没有就将数据传到name,对name进行reverse。但是这部分代码感觉还不够好,还需要进一步的修改。
if(localStorage.length!=0)
        {
            console.log(localStorage.length);
            var name = JSON.parse(localStorage['activity_name']);
            $scope.name = name.reverse();
        }
        else{
        }
 

 

8.在create_activity页面中要实现存入活动名称,判断活动名称是否重复以及返回按钮在活动列表中没有活动是不显示的三个功能。在存入活动时使用的方法是JSON.stringify方法,因为这个方法可以直接解析对象。在判断活动名称是否重复时使用的循环,在按钮显示的功能使用的是ng-show的方法。这部分的代码感觉也是不够干净利落,还是需要继续修改完善的。

<h3>活动名称</h3>
            <p><input type="text" class="input" ng-model="activity_name"></p>
            <button class="btn btn-default btn-lg btn-block" ng-disabled='!activity_name' ng-click="go_sign_up(activity_name)">创建</button>
            <p>{{tips}}</p>

 

if (localStorage.length != 0) {
                var storedNames = [];
                storedNames = JSON.parse(localStorage['activity_name']);
                var i = 0;
                for (var n = 0; n<storedNames.length; n++) {
                    if (storedNames[n]==temp_act_name) {
                        $scope.tips = "活动名称重复";
                        i = 1;
                        break;
                    }
                    else {
                    }
                }
                if(i==0){
                    storedNames.push(temp_act_name);  //将活动名称存入数组name
                    localStorage['activity_name'] = JSON.stringify(storedNames);
                    //将name数组存入localStorage中,key是activity_name
                    $location.path('/activity_sign_up');
                }
                else{
                }
            } else {
                var name = [];
                name.push(temp_act_name);
                localStorage['activity_name'] = JSON.stringify(name);
                $location.path('/activity_sign_up');
            }
        }

 至此,party_bid的第一张卡片的功能已经大致实现。但是里面还是有很多内容值得我细细思考,认真记录的。其实还是有一个疑问可不可以使用setItem和getItem的方法实现数据的存储和读取的呢?感觉上还是可以的,但是这两种方法哪一种更好呢?希望在下一篇博客中我可以得到结论。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!
提供的源码资源涵盖了小程序应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值