成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

大道至簡(jiǎn)--API設(shè)計(jì)的美學(xué)

jsyzchen / 1702人閱讀

摘要:對(duì)團(tuán)隊(duì)而言,如果有統(tǒng)一的規(guī)范命名,交接時(shí)可以減少大量的學(xué)習(xí)和溝通成本。當(dāng)時(shí)一直不知道是什么玩意,后來(lái)向那個(gè)人打聽才知道,是執(zhí)行登錄的操作,是中文拼音,又是英文,這樣的命名。

1.前言

對(duì)于前端開發(fā)而言,肯定會(huì)和API打交道,大家也都會(huì)想過(guò)怎么設(shè)計(jì)自己的API。優(yōu)秀的 API 之于代碼,就如良好內(nèi)涵對(duì)于每個(gè)人。好的 API 不但利于使用者理解,開發(fā)時(shí)也會(huì)事半功倍,后期維護(hù)更是順風(fēng)順?biāo)V劣谠趺丛O(shè)計(jì)API,今天就提下我自己的一些建議。如果大家有什么好的想法,歡迎指點(diǎn)。

2.命名

良好的一個(gè)命名習(xí)慣,就是效率開發(fā)的第一步。如果命名規(guī)范,對(duì)自己而言,文件整理有很大的幫助,后期修改文件、可以快速的定位文件,命名規(guī)范,也顯得自己專業(yè)。對(duì)團(tuán)隊(duì)而言,如果有統(tǒng)一的規(guī)范命名,交接時(shí)可以減少大量的學(xué)習(xí)和溝通成本。

關(guān)于命名,下面提點(diǎn)幾個(gè)小建議

2-1.正確拼寫

這個(gè)應(yīng)該說(shuō)是命名的一個(gè)底線了,經(jīng)常性出現(xiàn),單詞拼寫錯(cuò)誤,搞得自己或者團(tuán)隊(duì)的人都一頭霧水的情況不再少數(shù)。我遇到情況比較深刻的有

中文大意 期望 實(shí)際
表單 form from
報(bào)名 sign-up sign-in
采納 adopt adept
內(nèi)容 content contend
測(cè)試 test text
聯(lián)系 contact contract
高度 height heigth
寬度 width widht
移動(dòng) mobile moblie
標(biāo)簽 tab tap

這些單詞,如果是拼寫錯(cuò)誤還好,至少編輯器都會(huì)提醒。但是如果寫錯(cuò)了,但是單詞又是正確的單詞就可大可小了(表單,報(bào)名,采納,內(nèi)容這些例子,單詞寫錯(cuò)了,意思變了,但是單詞是正確的,編輯器都不會(huì)提醒)。

試過(guò)挖坑比較深的一次就是:一個(gè)活動(dòng),有報(bào)名,有簽到的功能!處理方法如下

獲取已報(bào)名用戶信息:getSignUpUserList,
重置報(bào)名的數(shù)據(jù):resetSignUpUser,
提交報(bào)名操作:signInDo

獲取已簽到用戶信息:getSignInUserList,
重置簽到的表單數(shù)據(jù):resetSignInUser,
提交簽到的操作:signUpDo

修改bug的時(shí)候,完全懵逼了,原因大家懂的。

2-2.注意單復(fù)數(shù)

所有涉及遍歷,操作對(duì)象,數(shù)組,集合的函數(shù),建議都采用復(fù)數(shù)。

對(duì)于展現(xiàn)復(fù)數(shù),不同公司有不同的習(xí)慣,但是得統(tǒng)一,比如產(chǎn)品列表-productList。這里用了list表示復(fù)數(shù),再其它地方,就不建議使用products這種方式表示復(fù)數(shù)了
2-3.用詞準(zhǔn)確

這個(gè)主要的兩方面的內(nèi)容

2-3-1.單詞意思搞錯(cuò)

比如彈窗上面的信息,有些時(shí)候見到,使用包含notice的字樣,但是實(shí)際上,notice的中文意思,準(zhǔn)確的應(yīng)該是‘公告,告示,聲明’之類。
一個(gè)彈窗這樣的會(huì)話消息,建議使用message這個(gè)字樣。notice應(yīng)該像‘公告,告示,聲明’之類的情況使用。

2-3-2.正反詞義單詞錯(cuò)用

比如關(guān)閉彈窗的方法,的方法是closeDialog,然后顯示彈窗用的又是showDialogshow的意思是‘顯示’,反義詞應(yīng)該是hide‘隱藏’。而close意思是關(guān)閉,反義詞應(yīng)該是open

附常用反義詞組(有些帶縮寫)

in out
on off
prev next
show hide
close open
success fail
before after
begin end
2-4.命名意義

這一塊,本來(lái)打算放在2-2里面講的,因?yàn)槊绻幸饬x也是一個(gè)底線。但是最后放在這里,是因?yàn)檫@個(gè)情況在函數(shù)里面出現(xiàn)得不多,更多應(yīng)該出現(xiàn)在普通變量里面(相信很多人會(huì)遇到過(guò)這樣的命名:var n1,n2,n3;)。關(guān)于命名,還是建議大家要起有意義名稱,不使用沒(méi)意義的命名。

遇到最多的情況,就是圖標(biāo)的命名方面。

比如下面的圖標(biāo)(選自某平臺(tái)的底部導(dǎo)航欄),點(diǎn)擊不同的圖標(biāo)出發(fā)不同的方法。

很多人喜歡下面的命名

//版本1
function handle1(){

}
function handle2(){

}
//版本2
function handleA(){

}
function handleB(){

}
//版本3
function handleOne(){

}
function handleTwo(){

}

這樣的命名,別人函數(shù)了,就算是元素的 class 。這樣的命名在后期維護(hù)絕對(duì)增加了難度。甚至可能導(dǎo)致重構(gòu)。

建議的姿勢(shì)

function handleHome(){

}
function handleCollect(){

}

2-5.命名格式

文章說(shuō)的API,主要針對(duì)的是函數(shù),但是在這一小塊里面,也列舉一下其它的目標(biāo)的建議命名方式。

待命名對(duì)象 推薦名稱
圖片 ‘-’ ‘_’ 分割
class,id ‘-’ 分割
文件,變量 駝峰命名
臨時(shí)變量 ‘_’ 開頭,駝峰命名
2-6.處理中文拼音

對(duì)于中文拼音,應(yīng)該說(shuō)只有一種情況,被中國(guó)人創(chuàng)造出來(lái),沒(méi)有英文翻譯的。

命名 含義
taobao 淘寶
weibo 微博
zongzi 粽子
pinyin 拼音
在一年多以前,遇到一個(gè)中二的命名-dengluDo。當(dāng)時(shí)一直不知道是什么玩意,后來(lái)向那個(gè)人打聽才知道,是執(zhí)行登錄的操作,denglu是中文拼音,do又是英文,這樣的命名。后期如果維護(hù),他不哭,算我輸。
2-7.命名潛規(guī)則

有些情況,給特定的對(duì)象命名,還要用特定的名字,可以說(shuō)是潛規(guī)則吧。印象最清楚的就是給按鈕命名要么全拼,要么寫btn。很清楚的記得我一個(gè)老師說(shuō)過(guò):寫but,bto的程序也能正常運(yùn)行,也沒(méi)人說(shuō)你錯(cuò),但是我做面試官,就是不錄用你,就說(shuō)你不專業(yè)。

待命名對(duì)象 推薦名稱 錯(cuò)誤示范
按鈕 btn but bto
背景 bg back background
模板 tpl tem
提示信息 msg mes
標(biāo)簽欄 tab tit
網(wǎng)站大圖(廣告宣傳圖) banner ban
注冊(cè) register sign-in
3.參數(shù)

對(duì)于函數(shù)而言,參數(shù)是用戶設(shè)置最頻繁,也是最關(guān)心的部分,合理設(shè)計(jì)函數(shù)參數(shù),這一步很重要,直接影響函數(shù)的使用。

3-1.const入?yún)?/b>

這個(gè)應(yīng)該說(shuō)是一個(gè)習(xí)慣吧,不要直接改變?nèi)雲(yún)⒌闹?。這個(gè)規(guī)則的初衷是解決函數(shù)副作用問(wèn)題。如果參數(shù)是一個(gè)引用類型的數(shù)據(jù),如果在函數(shù)內(nèi)修改了參數(shù),到時(shí)候?qū)?huì)使得原本的數(shù)據(jù)發(fā)生改變,往往會(huì)發(fā)生難以追蹤的問(wèn)題。

3-2.控制參數(shù)數(shù)量

參數(shù)的數(shù)量,個(gè)人建議就是,超過(guò)3個(gè),使用對(duì)象進(jìn)行封裝。因?yàn)槿绻鸄PI參數(shù)越多,那么使用對(duì)于這個(gè)API的記憶成本就越大,易用性也很受影響。

比如下面的例子:

encryptStr: function (str, regArr, type, replacement) {
    var regtext = "",
        Reg = null,
        _type=type||0,
        replaceText = replacement || "*";
    //ecDo.encryptStr("18819322663",[3,5,3],0)
    //result:188*****663
    //repeatStr是在上面定義過(guò)的(字符串循環(huán)復(fù)制),大家注意哦
    if (regArr.length === 3 && type === 0) {
        regtext = "(w{" + regArr[0] + "})w{" + regArr[1] + "}(w{" + regArr[2] + "})"
        Reg = new RegExp(regtext);
        var replaceCount = this.repeatStr(replaceText, regArr[1]);
        return str.replace(Reg, "$1" + replaceCount + "$2")
    }
    //ecDo.encryptStr("asdasdasdaa",[3,5,3],1)
    //result:***asdas***
    else if (regArr.length === 3 && type === 1) {
        regtext = "w{" + regArr[0] + "}(w{" + regArr[1] + "})w{" + regArr[2] + "}"
        Reg = new RegExp(regtext);
        var replaceCount1 = this.repeatStr(replaceText, regArr[0]);
        var replaceCount2 = this.repeatStr(replaceText, regArr[2]);
        return str.replace(Reg, replaceCount1 + "$1" + replaceCount2)
    }
    //ecDo.encryptStr("1asd88465asdwqe3",[5],0)
    //result:*****8465asdwqe3
    else if (regArr.length === 1 && type === 0) {
        regtext = "(^w{" + regArr[0] + "})"
        Reg = new RegExp(regtext);
        var replaceCount = this.repeatStr(replaceText, regArr[0]);
        return str.replace(Reg, replaceCount)
    }
    //ecDo.encryptStr("1asd88465asdwqe3",[5],1,"+")
    //result:"1asd88465as+++++"
    else if (regArr.length === 1 && type === 1) {
        regtext = "(w{" + regArr[0] + "}$)"
        Reg = new RegExp(regtext);
        var replaceCount = this.repeatStr(replaceText, regArr[0]);
        return str.replace(Reg, replaceCount)
    }
}

大家可以看上面的注釋,就知道這段代碼的具體作用了,如果想想就找個(gè)參數(shù),我必須要除了記得4個(gè)參數(shù)的作用,還要記得參數(shù)的順序。

如果使用對(duì)象記錄參數(shù),用戶只需要記得4個(gè)參數(shù)的作用,不需要記參數(shù)的順序。

encryptStr: function (obj) {
        var _default={
            type:0,
            replacement:"*"
        };
        for(var key in obj){
            _default[key]=obj[key];
        }
},

//調(diào)用方式
ecDo.encryptStr({str:"18819266335",regArr:[5],type:0,replacement:"-"});

這樣還有一個(gè)好處就是,比如像剛才的函數(shù),type這個(gè)參數(shù),我想保留默認(rèn)值,偷懶不傳。原來(lái)的方案,就得這樣傳。

ecDo.encryptStr("1asd88465asdwqe3",[5],"","+");

這樣肯定是會(huì)激起不少有代碼潔癖的開發(fā)者,比如我。如果使用對(duì)象,就很好避免了。

ecDo.encryptStr({str:"18819266335",regArr:[5],replacement:"-"});
3-3.前置相關(guān)性高的參數(shù)

這個(gè)應(yīng)該沒(méi)什么可能,就一個(gè)意思:必填重要的參數(shù)前置,可省略的參數(shù)后置。

比如下面的例子

/格式化處理字符串
//ecDo.formatText("1234asda567asd890")
//result:"12,34a,sda,567,asd,890"
//ecDo.formatText("1234asda567asd890",4," ")
//result:"1 234a sda5 67as d890"
//ecDo.formatText("1234asda567asd890",4,"-")
//result:"1-234a-sda5-67as-d890"
formatText: function (str, size, delimiter) {
    var _size = size || 3, _delimiter = delimiter || ",";
    var regText = "B(?=(w{" + _size + "})+(?!w))";
    var reg = new RegExp(regText, "g");
    return str.replace(reg, _delimiter);
},

調(diào)用大家都看得出來(lái)。如果API這樣設(shè)計(jì)

formatText: function (size, delimiter, str) {
    var _size = size || 3, _delimiter = delimiter || ",";
    var regText = "B(?=(w{" + _size + "})+(?!w))";
    var reg = new RegExp(regText, "g");
    return str.replace(reg, _delimiter);
},

就得這樣調(diào)用,如果這樣寫API,被批斗的可能性很大!

ecDo.formatText("","","1234asda567asd890")
4.作用 4-1.支持批量處理

比如這個(gè)例子,頁(yè)面有這樣的元素

有一個(gè)類似jQuery的css這個(gè)API的API。

css: function (dom, json) {
    for (var attr in json) {
        dom.style[attr] = json[attr];
    }
}

然后給這些div設(shè)置樣式的時(shí)候,代碼如下

var oDiv1 =document.querySelectorAll(".div1");
var oDiv2=document.querySelector("#div1");
ecDo.css(oDiv2,{"height":"100px","width":"100px","background":"#333"});
ecDo.css(oDiv1,{"height":"100px","width":"100px","background":"#09f"});

當(dāng)運(yùn)行到ecDo.css(oDiv1,{"height":"100px","width":"100px","background":"#09f"});會(huì)提示報(bào)錯(cuò),原因大家也知道。css這個(gè)API里面,只處理了單個(gè)元素,并沒(méi)有處理元素的集合。

建議的方式是把 css 這個(gè)API改成可批量處理元素集合的。

css: function (dom, json) {
    if (dom.length) {
        for (var i = 0; i < dom.length; i++) {
            for (var attr in json) {
                dom[i].style[attr] = json[attr];
            }
        }
    }
    else {
        for (var attr in json) {
            dom.style[attr] = json[attr];
        }
    }
},    
   
4-2.多態(tài)處理

一個(gè)類似jQuery的html這個(gè)API的API-html

之前遇到一個(gè)開發(fā)者的處理方式是:獲取元素的innerHTML和設(shè)置元素innerHTML分開為兩個(gè)方法-getHtml,setHtml。這樣的問(wèn)題又在于記憶的成本比原生的 innerHTML 還要高。建議的姿勢(shì)就是,獲取和設(shè)置用同一個(gè)API。

html: function (dom) {
    if (arguments.length === 1) {
        return dom.innerHTML;
    } else if (arguments.length === 2) {
        dom.innerHTML = arguments[1];
    }
}

ecDo.html(oDiv);//獲取
ecDo.html(oDiv,"守候");//設(shè)置
4-3.可擴(kuò)展性

可擴(kuò)展性,就是建議遵守開放-封閉原則。對(duì)擴(kuò)展開放,對(duì)修改關(guān)閉。比如jQuery的$.fn和$.fn.extend()。

說(shuō)一個(gè)簡(jiǎn)單的例子-計(jì)算加薪額度

var addMoney = (function () {
    //定義策略類
    var strategies = {
        A:function(money){
            return money + 2000;
        },
        B:function(money){
            return money + 1000;
        }
    };
    //暴露接口
    return {
        //根據(jù)等級(jí)和現(xiàn)工資,輸入加薪后的工資
        compute:function(lv,money){
            return strategies[lv](money)
        }
    };
})();

//比如:等級(jí)為A,5000+2000
console.log(addMoney.compute("A",5000))//7000
//比如:等級(jí)為B,20000+1000
console.log(addMoney.compute("B",20000))//21000

代碼看著沒(méi)有問(wèn)題,但是如果以后需求要增加C等級(jí)呢?這就不得不修改strategies。在里面增加方法。
如下

var strategies = {
    A:function(money){
        return money + 2000;
    },
    B:function(money){
        return money + 1000;
    },
    C:function(money){
        return money + 500;
    }
};

這樣實(shí)現(xiàn)也簡(jiǎn)單,如果以后要增加S等級(jí)呢?又得改strategies。這里還有一個(gè)問(wèn)題就是,如果增加的C等級(jí)只有在A模塊需要用到,在B模塊不會(huì)出現(xiàn),那么在B模塊引用addMoney的時(shí)候,又會(huì)把C等級(jí)的計(jì)算方式也引入進(jìn)去,造成不必要的資源浪費(fèi)。
建議的方式是,設(shè)置一個(gè)接口,擴(kuò)展strategies。

var addMoney = (function () {
    //定義策略類
    let strategies = {
        A:function(money){
            return money + 2000;
        },
        B:function(money){
            return money + 1000;
        }
    };
    //暴露接口
    return {
        //根據(jù)等級(jí)和現(xiàn)工資,輸入加薪后的工資
        compute:function(lv,money){
            return strategies[lv](money)
        },
        //擴(kuò)展等級(jí)
        addRule:function(lv,fn){
            strategies[lv]=fn;
        }
    };
})();
//增加C等級(jí)的調(diào)用
addMoney.addRule("C",function(money){
    return money + 500;
});
console.log(addMoney.compute("C",20000))//20500    
4-4.避免副作用

函數(shù)的副作用,相信很多人都會(huì)遇到過(guò),比如在一個(gè)函數(shù)體內(nèi)修改一個(gè)外部作用域的變量,或者全局變量,在函數(shù)體內(nèi)修改引用類型的參數(shù),這些情況多少都會(huì)遇到過(guò)。

如何避免呢?主要是以下兩個(gè)寫代碼習(xí)慣。

1.函數(shù)體內(nèi)可以使用參數(shù),進(jìn)行操作,但是不能修改。如果修改,用一個(gè)臨時(shí)變量記錄參數(shù)(如果是引用類型,需要用深拷貝記錄)。這樣可以避免直接修改參數(shù)。

2.對(duì)于函數(shù)外的變量,如全局變量。函數(shù)體內(nèi)可以訪問(wèn),但是不能修改。

3.如果需要給函數(shù)外的變量賦值,不能在函數(shù)體內(nèi)操作,把值返回到外部,在外部進(jìn)行賦值。(感覺(jué)這里有點(diǎn)啰嗦,因?yàn)橘x值了,就是修改了外部變量,就違反了第二點(diǎn))。

//不好做法
var myName="";
function setName(firstName,lastName){
    myName=firstName+lastName;
}
setName("守","侯");
//推薦做法
var myName="";
function setName(firstName,lastName){
    return firstName+lastName;
}
myName=setName("守","侯");


5.向下兼容

這個(gè)建議主要就是為了兼顧以前的寫法。還是拿上面的那個(gè)例子吧!
原本傳參方式是這樣

encryptStr: function (str, regArr, type, replacement) {};

后來(lái)升級(jí)改成這樣

encryptStr: function (obj){}

這樣問(wèn)題就來(lái)了,一個(gè)項(xiàng)目里面,因?yàn)闅v史的原因難免會(huì)使用這個(gè)API,并且使用了第一種方式傳參。現(xiàn)在API改了,解決的方案有兩個(gè),要么把整個(gè)項(xiàng)目使用的這個(gè)API的方式,都改成第二種的傳參方式,要么就是對(duì)接口進(jìn)行向下兼容,兼容以前的方案。

encryptStr: function (obj) {
    var _default={
        type:0,
        replacement:"*"
    };
    //如果還是以之前的方式調(diào)用函數(shù),兼容性判斷
    if(arguments.length>1){
        _default.str=arguments[0];
        _default.regArr=arguments[1];
        _default.type=arguments[2]||0;
        _default.replacement=arguments[3]||"*";
    }
    else{
        for(var key in obj){
            _default[key]=obj[key];
        }
    }
    //下面代碼略
},
如果API已經(jīng)準(zhǔn)備來(lái)一個(gè)大版本的更新,(比如從1.0.0升級(jí)到2.0.0,不是1.0.0升級(jí)到1.0.1,或者1.0.0升級(jí)到1.1.0)。不打算兼容以前的版本了。可以忽略這一步,畢竟兼容性的代碼可能也很多。
6.簡(jiǎn)單

這一步可以說(shuō)是API設(shè)計(jì)最高級(jí)的一步,也是最難開發(fā)的一步,這就是為什么這篇文章會(huì)帶有‘大道至簡(jiǎn)’的字樣,即使API的實(shí)現(xiàn)很難,但使用起來(lái)簡(jiǎn)單感覺(jué)就是高級(jí)的API。這一步也直接影響API的好用與否。簡(jiǎn)單的API不但是用起來(lái)簡(jiǎn)單,試試可以一看就懂的API。這樣的API更易理解、記憶、調(diào)試和變更使用方式。

原生的API,比如Date,some、map、find等所有數(shù)組遍歷操作函數(shù),es6提供的Object.assign,Object.keys,Object.values等。

曾經(jīng)的霸主jQuery,現(xiàn)在的王者react,黑馬vue。這些項(xiàng)目讓人拍手稱贊的原因雖然有很多,但也不可否認(rèn)的,那便是它們的API設(shè)計(jì)非常的巧妙。如:jQuery的$,siblings,toogleClass,animate等,react的cloneElement,replaceProps等,vue的nextTick,set等。

jQuery對(duì)于現(xiàn)在而言,雖然是過(guò)時(shí)了,但里面的知識(shí)還是值得學(xué)習(xí),比如使用的淋漓盡致的 js 寫作技巧,設(shè)計(jì)模式,以及 API 設(shè)計(jì)等。

自己寫的API,我也是把API寫得盡量的簡(jiǎn)單,最高境界就是讓別人掃一眼文檔,就知道記牢了API的使用方式。這個(gè)是我追求的目標(biāo),只是現(xiàn)在距離還是有點(diǎn)遠(yuǎn)。大家看我encryptStr這個(gè)API就知道(此處尷尬一天)。

7.小結(jié)

在我的眼里,一個(gè)好的API,會(huì)有一個(gè)一看就懂的名字,一個(gè)強(qiáng)大的功能,一個(gè)簡(jiǎn)單的調(diào)用方式。雖然只有三個(gè)條件,但是這三個(gè)條件結(jié)合起來(lái),可不是那么容易做到的。一個(gè)好的API,無(wú)論是對(duì)自己,對(duì)團(tuán)隊(duì),對(duì)項(xiàng)目開發(fā)都是一個(gè)很好的幫助。

對(duì)于設(shè)計(jì)API的一些個(gè)人建議,就到這里了,如果以后有更好的想法,會(huì)第一時(shí)間分享,和大家交流意見。如果大家有什么想法,歡迎指點(diǎn)迷津。

---------------------------華麗的分割線--------------------------------

想了解更多,關(guān)注我的微信公眾號(hào)-守候書閣

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/93501.html

相關(guān)文章

  • php+Mysql開發(fā)“二當(dāng)家素材”官網(wǎng)前后臺(tái)整站源碼

    摘要:演示效果源碼介紹該源碼是一套簡(jiǎn)潔大方的網(wǎng)站源碼,采用目前最流行的框架開發(fā),后臺(tái)布局采用。系統(tǒng)架構(gòu)清晰,功能強(qiáng)大,操作簡(jiǎn)單,秉承了大道至簡(jiǎn)的核心理念。 演示效果: http://www.erdangjiade.com/源碼介紹:該源碼是一套簡(jiǎn)潔大方的網(wǎng)站源碼,采用目前最流行的php框架php5.6+Mysql5.6+Apache2.4開發(fā),后臺(tái)布局采用BootStrap。系統(tǒng)架構(gòu)清晰,功...

    golden_hamster 評(píng)論0 收藏0
  • php+Mysql開發(fā)“二當(dāng)家素材”官網(wǎng)前后臺(tái)整站源碼

    摘要:演示效果源碼介紹該源碼是一套簡(jiǎn)潔大方的網(wǎng)站源碼,采用目前最流行的框架開發(fā),后臺(tái)布局采用。系統(tǒng)架構(gòu)清晰,功能強(qiáng)大,操作簡(jiǎn)單,秉承了大道至簡(jiǎn)的核心理念。 演示效果: http://www.erdangjiade.com/源碼介紹:該源碼是一套簡(jiǎn)潔大方的網(wǎng)站源碼,采用目前最流行的php框架php5.6+Mysql5.6+Apache2.4開發(fā),后臺(tái)布局采用BootStrap。系統(tǒng)架構(gòu)清晰,功...

    oogh 評(píng)論0 收藏0
  • php+Mysql開發(fā)“二當(dāng)家素材”官網(wǎng)前后臺(tái)整站源碼

    摘要:演示效果源碼介紹該源碼是一套簡(jiǎn)潔大方的網(wǎng)站源碼,采用目前最流行的框架開發(fā),后臺(tái)布局采用。系統(tǒng)架構(gòu)清晰,功能強(qiáng)大,操作簡(jiǎn)單,秉承了大道至簡(jiǎn)的核心理念。 演示效果: http://www.erdangjiade.com/源碼介紹:該源碼是一套簡(jiǎn)潔大方的網(wǎng)站源碼,采用目前最流行的php框架php5.6+Mysql5.6+Apache2.4開發(fā),后臺(tái)布局采用BootStrap。系統(tǒng)架構(gòu)清晰,功...

    Tamic 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<