成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專欄INFORMATION COLUMN

編寫大型項(xiàng)目web頁面 從寫web登陸頁面開始

騫諱護(hù) / 2932人閱讀

摘要:頁面搭建需要準(zhǔn)備什么工具首先我們會和設(shè)計(jì)師溝通我們需要一些檢驗(yàn)設(shè)計(jì)的工具自動裁圖自動測量工具我這里安利一下一個(gè)工具我用的可以使用阿里的工具拿到界面不要急著做看看有什么問題有些我都會問端問題如果要兼容我要考慮成本如果是一個(gè)人辦可能會出現(xiàn)時(shí)間的

web頁面搭建需要準(zhǔn)備什么工具 首先我們會和設(shè)計(jì)師溝通 我們需要一些檢驗(yàn)設(shè)計(jì)的工具

ps 自動裁圖 自動測量工具

(我這里安利一下一個(gè)工具 我用的cutterman)

sketch 可以使用阿里的工具 marketch

拿到界面不要急著做 看看有什么問題

有些我都會問

pc端

ie8問題 如果要兼容ie8 我要考慮成本

如果是webapp 一個(gè)人辦 可能會出現(xiàn)時(shí)間的問題 這個(gè)不要驚訝 一個(gè)人做webapp會不停重構(gòu)

mobile端

uc問題

除此之外最重要的 控制住ui節(jié)奏 和ui搞好關(guān)系 告訴他們自己大約什么進(jìn)度 要學(xué)會交流 不要設(shè)計(jì)出來 自己安排不過來就傻眼了

和后端溝通

咋們這頁面怎么和后端配合 ajax怎么測 會不會有mockdata

溝通 通常前端的位置是定位于前后端橋梁的 這個(gè)我會在后文多次強(qiáng)調(diào) 另外咱么這個(gè)文章是一系列的 每個(gè)ui的實(shí)現(xiàn) 我可能會解讀一下w3c文檔 可能就會占用一篇文章
構(gòu)建和審查工具

gulp
jshint
等等

技術(shù)選型

sass
postcss
typescript 或者 es6

登陸頁面簡單嗎

好像貌似很簡單 不就是一個(gè)表單嗎

表單簡單嗎 如果簡單js會因此流行開來嗎

表單當(dāng)然不簡單 驗(yàn)證怎么做

先做頁面 好的 這里問題來了 公司有沒有前端庫呢 有的話還簡單點(diǎn) 沒有就只能自己搭了

首先確認(rèn)一下 既然做指南 說下兼容目標(biāo) ie8 可以看 ie9 可以用
ie8 最后解決 ie8解決問題 至少該pc端項(xiàng)目得配兩個(gè)人

如何給css加ie的hack




ie 的模式

也許有的頁面會移動端也用

    

360的保護(hù)

聽說標(biāo)準(zhǔn)很值錢 dom4 有classlist奧


開始寫

不急 我們先規(guī)劃下
首先node_modules已成為事實(shí)上前端包管理目錄 所以我們要在里面建立一個(gè)ui庫

我自己一直在穩(wěn)定更新自己的ui庫zhilizhili-ui

ui布局 一開始要確定的
color
font

--某個(gè)項(xiàng)目靜態(tài)目錄
  -- framework  
     -- elements
  -- my module   
      -- sass
        _color.scss 
        _font.scss

__color.scss

$custom-color: (
        "blue": (
                "500": #0f8ffe,
                "600": #0088ff
        ),
        "red": (
                "600": #f26c4f
        ),
        "green": (
                "600": #d6e9ba
        ),
        "yellow": (
                "600": #ecf82c
        ),
        "purple": (
                "600": #e22cf8
        ),
        "grey": (
                "400": #c2c2c2,
                "500": #898989,
                "600": #464646
        )
) !global;

@function get-custom-color($name, $level: "600") {
  @return map-deep-get($custom-color, $name, $level);
}

_font.scss

@import "../../../../../node_modules/sassstd/src/sassstd";
@import "../../../../../node_modules/sassyjson/stylesheets/SassyJSON";
@import "../../../../../node_modules/scss-zhilizhili-mei/stylesheets/mei";

@import "../../../../../node_modules/zhilizhili-ui/framework/sass/utils/full-parent";
@import "../../../../../node_modules/zhilizhili-ui/framework/sass/utils/size";
@import "../../../../../node_modules/zhilizhili-ui/framework/sass/utils/bem";
@import "../../../../../node_modules/zhilizhili-ui/framework/sass/utils/query-selector";
@import "../../../../../node_modules/zhilizhili-ui/framework/sass/common/sim-querySelector";

@mixin interface-font() {
  .font {
    @content;
  }
}

@mixin use-font() {
  $defaults: (
    ".font": (
    )
  );

  @include interface-font() {
    @include register-hook("font");
    @content;
  }
}

@mixin use-amazeui-font($sel: body) {
  #{$sel} {
    font-family: "Segoe UI", "Lucida Grande", Helvetica, Arial, "Microsoft YaHei", FreeSans, Arimo, "Droid Sans","wenquanyi micro hei","Hiragino Sans GB", "Hiragino Sans GB W3", Arial, sans-serif;
  }
}

font.scss 使用的是自己整合的sassstd 這是自己搜集的sass庫
提供一些string map list的高級方法 還有等等啦

scss-zhilizhili-mei 提供了一些簡單的設(shè)計(jì)想法

大家平時(shí)一定要遵循dry法則
大家編寫樣式時(shí)盡量使用sass或者postcss寫法 不要直接寫css 這樣做目的 希望代碼可讀性增加 模塊化 就算現(xiàn)在只有你一個(gè)人 如果團(tuán)隊(duì)來新人 或者你離職 代碼交給別人維護(hù) 大家都是程序員 何苦為難自己人

_color.scss

$custom-color: (
        "blue": (
                "500": #0f8ffe,
                "600": #0088ff
        ),
        "red": (
                "600": #f26c4f
        ),
        "green": (
                "600": #d6e9ba
        ),
        "yellow": (
                "600": #ecf82c
        ),
        "purple": (
                "600": #e22cf8
        ),
        "grey": (
                "400": #c2c2c2,
                "500": #898989,
                "600": #464646
        )
) !global;

@function get-custom-color($name, $level: "600") {
  @return map-deep-get($custom-color, $name, $level);
}

首先項(xiàng)目一開始會有一個(gè)color的基本表述文件 定義為sass的一個(gè)全局變量
但是一些活動頁面會有一些特殊的顏色 怎么辦呢

$custom-color: map-extend($custom-color, (
        "pink": (
                "600": #f54c72
        ),
        "green": (
                "600": #4bbf4a
        ),
        "blue": (
                "600": #5093e1
        ),
        "purple": (
                "600": #442488
        ),
        "grey": (
                "200": #fbfbfb,
                "300": #EDEFF5,
                "400": #EAECEC,
                "500": #A4ADBF,
                "600": #50535E
        )
)) !global;

使用map-extend 就可以修改custom-color顏色 如果當(dāng)前頁面有特殊顏色需求 就這么解決

一個(gè)標(biāo)準(zhǔn)的項(xiàng)目準(zhǔn)備開始 我們需要什么呢 我們可以看張圖

這是android material design的設(shè)計(jì) 下篇文章我們把前端樣式這邊梳理一下

編寫頁面代碼
    

沒什么好說的 就是一些表單元素

編寫js代碼

在編寫代碼的之前 解決一些瀏覽器bug

ie9 input事件bug

// ie9 input 事件polyfill
(function (d) {
    if (navigator.userAgent.indexOf("MSIE 9") === -1) return;
    var elements = [], values = [], ev = d.createEvent("CustomEvent");
    ev.initCustomEvent("input", true, true, {});

    d.addEventListener("selectionchange", function() {
        var actEl = d.activeElement;

        if (actEl.tagName === "TEXTAREA" || (actEl.tagName === "INPUT")) {
            var idx = elements.indexOf(actEl), el = elements[idx] || elements.push(actEl);
            if (actEl.type === "text" || actEl.type === "password" || actEl.type === "search") {
                if (el.value !== values[idx]) {
                    values[idx] = el.value;
                    el.dispatchEvent(ev);
                }
            }
        }
    });
})(document);

對于登陸而言 js驗(yàn)證時(shí)一件很重要的事 通常需要解決 輸入時(shí)檢測 提示 提交時(shí) 監(jiān)測 提示

這里我的想法是 提供一種通用寫法 具體實(shí)現(xiàn) 可以不一樣

假設(shè)整個(gè)項(xiàng)目有一個(gè)通用的validator的對象 這個(gè)實(shí)現(xiàn)不強(qiáng)求
我用的是validator.js if 后面是 觸發(fā)事件名稱 do 是驗(yàn)證方法
這種在html上寫的語句 我叫做sml

// 解析sml
utils.sml = (function() {
    function parse(str) {
        var parseobj = {};
        parseobj["event"] = str.match(/(?:if:)s*w*/g)[0].replace("if:", "").trim();
        parseobj["regex"] = str.match(/(?:do:)[sw(),|]+/g)[0].replace("do:", "").split("|").map(function(item) {
            var args = [];
            var reg = /(?:()[ws,]+/g;
            if (item.indexOf("(") > -1 && item.indexOf(")") > -1) {
                var val = item.match(reg)[0].replace("(", "").split(",");
                args = args.concat(val);
            }
            return {
                name: item.trim().replace(reg, "").replace(")", ""),
                args: args
            };
        });
        return parseobj;
    }

    return {
        parse: parse
    }
})();
data-regex="if: input, do: min(6) | max(15);"

如果有多個(gè)驗(yàn)證 就是用分隔符隔開 多個(gè)驗(yàn)證第一次錯(cuò)誤時(shí)就退出

任何驗(yàn)證都要提供 regex-error 和 regex-success 兩個(gè)方法

再說組件 每個(gè)html 組件 目前我是用vue實(shí)現(xiàn)的 但是我決定用angular2做了 所以不怎么說了

框架的validtor 需要保留每個(gè)待驗(yàn)證的方式 以便使用submit提交時(shí)可以驗(yàn)證 以便實(shí)現(xiàn)組件于頁面邏輯的結(jié)構(gòu)

form 組件我會寫幾篇文章

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.hztianpu.com/yun/111237.html

相關(guān)文章

  • 編寫大型項(xiàng)目web頁面 從寫web登陸頁面開始

    摘要:頁面搭建需要準(zhǔn)備什么工具首先我們會和設(shè)計(jì)師溝通我們需要一些檢驗(yàn)設(shè)計(jì)的工具自動裁圖自動測量工具我這里安利一下一個(gè)工具我用的可以使用阿里的工具拿到界面不要急著做看看有什么問題有些我都會問端問題如果要兼容我要考慮成本如果是一個(gè)人辦可能會出現(xiàn)時(shí)間的 web頁面搭建需要準(zhǔn)備什么工具 首先我們會和設(shè)計(jì)師溝通 我們需要一些檢驗(yàn)設(shè)計(jì)的工具 ps 自動裁圖 自動測量工具 (我這里安利一下一個(gè)工具 我用...

    cangck_X 評論0 收藏0
  • 編寫大型項(xiàng)目web頁面 從寫web登陸頁面開始

    摘要:頁面搭建需要準(zhǔn)備什么工具首先我們會和設(shè)計(jì)師溝通我們需要一些檢驗(yàn)設(shè)計(jì)的工具自動裁圖自動測量工具我這里安利一下一個(gè)工具我用的可以使用阿里的工具拿到界面不要急著做看看有什么問題有些我都會問端問題如果要兼容我要考慮成本如果是一個(gè)人辦可能會出現(xiàn)時(shí)間的 web頁面搭建需要準(zhǔn)備什么工具 首先我們會和設(shè)計(jì)師溝通 我們需要一些檢驗(yàn)設(shè)計(jì)的工具 ps 自動裁圖 自動測量工具 (我這里安利一下一個(gè)工具 我用...

    DevTTL 評論0 收藏0
  • 【Java EE】從零開始項(xiàng)目【總結(jié)】

    摘要:目前該功能并未完善,敬請期待。反正每次都會有新的東西補(bǔ)充上去一開始我本來想做的是可以使用微信登陸,也可以使用賬戶郵箱登陸,也可以使用短信登陸的。后來發(fā)現(xiàn)微信登陸要企業(yè)認(rèn)證,做不了。 從零開發(fā)項(xiàng)目概述 最近這一直在復(fù)習(xí)數(shù)據(jù)結(jié)構(gòu)和算法,也就是前面發(fā)出去的排序算法八大基礎(chǔ)排序總結(jié),Java實(shí)現(xiàn)單向鏈表,棧和隊(duì)列就是這么簡單,十道簡單算法題等等... 被虐得不要不要的,即使是非常簡單有時(shí)候繞半...

    imtianx 評論0 收藏0
  • 編寫大型項(xiàng)目web頁面 樣式基礎(chǔ)搭建

    摘要:文中的一些方法來源于我的有出售請大家自行拷貝粘貼顏色要使用代詞加數(shù)字大小形式數(shù)字規(guī)格顏色變量不許由或者方法計(jì)算得出項(xiàng)目顏色基于配色基礎(chǔ)色庫設(shè)計(jì)師都會配出來項(xiàng)目色庫需要項(xiàng)目去改變設(shè)計(jì)師文字和前端頁面開發(fā)者文字必須為同一類 文中sass的一些方法 來源于我的sassstd zhilizhili-mei zhilizhili-ui npm 有出售 請大家自行拷貝粘貼 showImg(ht...

    smartlion 評論0 收藏0
  • 編寫大型項(xiàng)目web頁面 樣式基礎(chǔ)搭建

    摘要:文中的一些方法來源于我的有出售請大家自行拷貝粘貼顏色要使用代詞加數(shù)字大小形式數(shù)字規(guī)格顏色變量不許由或者方法計(jì)算得出項(xiàng)目顏色基于配色基礎(chǔ)色庫設(shè)計(jì)師都會配出來項(xiàng)目色庫需要項(xiàng)目去改變設(shè)計(jì)師文字和前端頁面開發(fā)者文字必須為同一類 文中sass的一些方法 來源于我的sassstd zhilizhili-mei zhilizhili-ui npm 有出售 請大家自行拷貝粘貼 showImg(ht...

    Dean 評論0 收藏0

發(fā)表評論

0條評論

閱讀需要支付1元查看
<