上一篇Node.Js切近实战讲述了如何在VS上搭建Node.Js开发环境,相信看过那篇博客的同学,你已经对Node.Js有了好感,多了解些技术还是很有必要的。所谓实战见真功,还是要实战才行。我看博客园上一些专家荣誉的人写的博客,全是理论,没有实战,没有实战就没有发言权。熟能生巧,实战出理论。
我们看一下项目结构
典型的NodeJs三层架构,controller,model,view,这里每个部分什么职能,我就不多说了。
首先我们看一下登录界面,先上图,我看博客的时候,会首先看博客中有没有图,比如一篇博客讲的是实时通讯或者自己包装了一个html5播放器,结果整篇博客全是代码和汉字,没有图片,这样的博客也没有什么吸引力。废话不多说,看看界面。
还是BootStrap布局,只是我将BootStrap的primary样式改了下,变成Telerik Kendo UI中的primary样式,因为后面的话我们是要使用Kendo UI去做前端UI的。Telerik Kendo UI for Html5是很不错的,样式美观大方,支持Jquey和Angualr JS。地址: http://www.telerik.com/kendo-ui
其实这个登录界面很简单,还是使用jade模板,代码如下
doctype htmlhtml head base(href='/') title #{title} link(rel='stylesheet', href='/stylesheets/style.css') link(rel='stylesheet',href='/stylesheets/bootstrap/css/bootstrap.min.css') link(rel='stylesheet',href='/stylesheets/bootstrap/css/bootstrap-theme.min.css') link(rel='stylesheet',href='/stylesheets/kendo/kendo.common-material.min.css') link(rel='stylesheet',href='/stylesheets/kendo/kendo.material.min.css') script(src='/javascripts/thirdpart/angular.min.js',type="text/javascript") body(style='background-color:#CCCCCC;') #main_layout(ng-app='loginModule' ng-controller='loginController') .panel.panel-primary .panel-heading h3.panel-title img(src='/images/userlogin.png' style='width:25px;height:25px') label.left-margin-10 User login form(ng-submit='loginIn()' role='form') div.panel-content .center-align-text h3 Please Enter your Information .row .col-md-12.row-margin .input-group.row-margin span.input-group-addon(style='background-color:#FF9900') img.input-group-img(src='/images/userno.png') input.form-control(ng-model='Login.UserName' type='text' autofocus='autofocus' placeholder='Please input user name' maxlength=15 required title='User name can\'t be empty!') .col-md-12.row-margin-large .input-group span.input-group-addon(style='background-color:#009966') img.input-group-img(src='/images/password.jpg') input.form-control(ng-model='Login.Password' type='password' placeholder='Please input password' required maxlength='15' title='Password can\'t be empty!') .col-md-12.row-margin-large(style='margin-bottom:10px') .col-md-6 div.row-middle-height input#chk_remember.k-checkbox(type='checkbox' ng-model='IsRemember' ng-true-value='true' ng-false-value='false') label.k-checkbox-label(for='chk_remember') Remember me .col-md-6 .right-align-text.row-middle-height button.k-button.k-primary(type='submit') Login .row.row-margin .center-align-text span(ng-show='IsLoading') img(src='/stylesheets/images/loading_2x.gif') span(style='color:#337ab7;font-weight:bold') login,please wait......script(type='text/javascript' src='/javascripts/local/login.js')
大家看到了,使用angularJs做前端数据绑定,有些人说这是MVC模式,我看是MVVM模式还差不多,做过Silverlight和WPF的同学肯定会认为这是MVVM模式。OK,在这里我们使用Html5的验证,效果

The article discusses the HTML <datalist> element, which enhances forms by providing autocomplete suggestions, improving user experience and reducing errors.Character count: 159

The article discusses the HTML <progress> element, its purpose, styling, and differences from the <meter> element. The main focus is on using <progress> for task completion and <meter> for stati

The article discusses using HTML5 form validation attributes like required, pattern, min, max, and length limits to validate user input directly in the browser.

The article discusses the <iframe> tag's purpose in embedding external content into webpages, its common uses, security risks, and alternatives like object tags and APIs.

The article discusses the HTML <meter> element, used for displaying scalar or fractional values within a range, and its common applications in web development. It differentiates <meter> from <progress> and ex

The article discusses the viewport meta tag, essential for responsive web design on mobile devices. It explains how proper use ensures optimal content scaling and user interaction, while misuse can lead to design and accessibility issues.

Article discusses best practices for ensuring HTML5 cross-browser compatibility, focusing on feature detection, progressive enhancement, and testing methods.

This article explains the HTML5 <time> element for semantic date/time representation. It emphasizes the importance of the datetime attribute for machine readability (ISO 8601 format) alongside human-readable text, boosting accessibilit


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

WebStorm Mac version
Useful JavaScript development tools

Atom editor mac version download
The most popular open source editor

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment
