隨筆-5  評論-0  文章-0  trackbacks-0
            2011年12月28日
               摘要: Web開發(fā)的mvc模式及改進  閱讀全文
          posted @ 2011-12-28 22:53 人稱小雨 閱讀(139) | 評論 (0)編輯 收藏
            2011年12月12日
          1.font-size:     字體大小
          2.color:           顏色
          3.font-family:   字體類型
          4.font-style:     斜體italic
          5.font-weight: 字體加粗bold
          6.text-transform: 大小寫,uppercase大寫或者lowercase小寫
          7.text-decoration: 裝飾,經(jīng)常給超鏈中的字體使用,underline下劃線,overline上劃線,linethrough中間刪除線
          8.letter-spacing,word-spacing: 字母間距和單詞(字)間距,漢字沒有字母間距
          9.line-height:     行間距,算法很奇怪,從行的底部到上面行的底部這個和div或span的height相等的話 字體會自動居中
          10.text-align:     對齊方式,左left中center右right  圖片后面加的文字說明則是上top中center下bottom

          11.text-indent : 首行縮進,一般是2em(騰訊代碼里面寫的2rem不知道什么意思,哪位大哥知道的話請留言。。。謝謝!)
          12.margin:         邊距,四個方向,top,right,bottom,left;涉及盒子模型跟padding,border要區(qū)分清楚
          13.overflow:       超出范圍的內(nèi)容顯示方式,很少使用auto和其它的,一般都是hidden不顯示
          14.background-image:   背景圖片
               background-repeat:  重復(fù)方式,no-repeat不重復(fù),repeat-x橫向重復(fù)一行,repeat-y縱向重復(fù)一行,應(yīng)該沒有對角重復(fù)
               background-position:  圖片的位置,這個是用非常頻繁,五個值top,right,bottom,left,center以及神奇的具體位置定位,也就是圖片的偏移技術(shù)

          15.border-collapse: 單像素表格消除重復(fù)邊框,值為collapse
          16.border-radius:    邊框的圓角程度可以寫四個,上右下左,也可以寫一個代表所有
          17.text-shaw,box-shadow:   文字的陰影效果和邊框的陰影效果,變化不大但是效果很好
          18. position:    定位,絕對定位absolute,相對定位relative,及固定定位fixed(一些網(wǎng)站的導(dǎo)航條經(jīng)常這么做),再加上可以使用的顯示層z-index,用處非常大;
          19. float:     浮動,值有right右浮動,left左浮動,需要注意的是一旦剩余位置大小不夠時這個塊會自動往下一行排
          20.display:    展示方式,block塊,inline行,inline-block和none隱藏
                              需要提的是這個inline-block,一個inline的行級標(biāo)簽如span,它們的高度是無法調(diào)整的,但是使用display:block改為塊級后可以,這樣可能會出現(xiàn)一些不想看到的效果。因此                       改為display:inline-block后可以調(diào)整高度也沒有塊級的一些效果
                雖然使用一些css插件可以做的更多更好,但是我還是覺得css必須精通才可以對自己的作品了如指掌,javaScript也是如此,會使用插件EXTjs、jQuery等等是必須的,但是基礎(chǔ)也同樣重要。歡迎大家留言、指導(dǎo)。小子是新手,錯的地方還希望前輩們多多指點!




          posted @ 2011-12-12 11:16 人稱小雨 閱讀(192) | 評論 (0)編輯 收藏
            2011年11月9日

          良好的編程原則與良好的設(shè)計工程原則密切相關(guān)。本文總結(jié)的這些設(shè)計原則,幫助開發(fā)者更有效率的編寫代碼,并幫助成為一名優(yōu)秀的程序員。

          1.避免重復(fù)原則(DRY – Don’t repeat yourself)

          編程的最基本原則是避免重復(fù)。在程序代碼中總會有很多結(jié)構(gòu)體,如循環(huán)、函數(shù)、類等等。一旦你重復(fù)某個語句或概念,就會很容易形成一個抽象體。

          2.抽象原則(Abstraction Principle )

          與DRY原則相關(guān)。要記住,程序代碼中每一個重要的功能,只能出現(xiàn)在源代碼的一個位置。

          3.簡單原則(Keep It Simple and Stupid )

          簡單是軟件設(shè)計的目標(biāo),簡單的代碼占用時間少,漏洞少,并且易于修改。

          4.避免創(chuàng)建你不要的代碼 Avoid Creating a YAGNI (You aren’t going to need it)

          除非你需要它,否則別創(chuàng)建新功能。

          5.盡可能做可運行的最簡單的事(Do the simplest thing that could possibly work)

          盡可能做可運行的最簡單的事。在編程中,一定要保持簡單原則。作為一名程序員不斷的反思“如何在工作中做到簡化呢?”這將有助于在設(shè)計中保持簡單的路徑。

          6.別讓我思考(Don’t make me think )

          這是Steve Krug一本書的標(biāo)題,同時也和編程有關(guān)。所編寫的代碼一定要易于讀易于理解,這樣別人才會欣賞,也能夠給你提出合理化的建議。相反,若是繁雜難解的程序,其他人總是會避而遠之的。

          7.開閉原則(Open/Closed Principle)

          你所編寫的軟件實體(類、模塊、函數(shù)等)最好是開源的,這樣別人可以拓展開發(fā)。不過,對于你的代碼,得限定別人不得修改。換句話說,別人可以基于你的代碼進行拓展編寫,但卻不能修改你的代碼。

          8.代碼維護(Write Code for the Maintainer)

          一個優(yōu)秀的代碼,應(yīng)當(dāng)使本人或是他人在將來都能夠?qū)λ^續(xù)編寫或維護。代碼維護時,或許本人會比較容易,但對他人卻比較麻煩。因此你寫的代碼要盡可能保證他人能夠容易維護。用書中原話說“如果一個維護者不再繼續(xù)維護你的代碼,很可能他就有想殺了你的沖動。”

          9.最小驚訝原則(Principle of least astonishment)

          最小驚訝原則通常是在用戶界面方面引用,但同樣適用于編寫的代碼。代碼應(yīng)該盡可能減少讓讀者驚喜。也就是說,你編寫的代碼只需按照項目的要求來編寫。其他華麗的功能就不必了,以免弄巧成拙。

          10.單一責(zé)任原則(Single Responsibility Principle) 

          某個代碼的功能,應(yīng)該保證只有單一的明確的執(zhí)行任務(wù)。

          11.低耦合原則(Minimize Coupling)

          代碼的任何一個部分應(yīng)該減少對其他區(qū)域代碼的依賴關(guān)系。盡量不要使用共享參數(shù)。低耦合往往是完美結(jié)構(gòu)系統(tǒng)和優(yōu)秀設(shè)計的標(biāo)志。

          12.最大限度凝聚原則(Maximize Cohesion)

          相似的功能代碼應(yīng)盡量放在一個部分。

          13.隱藏實現(xiàn)細節(jié)(Hide Implementation Details)

          隱藏實現(xiàn)細節(jié)原則,當(dāng)其他功能部分發(fā)生變化時,能夠盡可能降低對其他組件的影響。

          14.迪米特法則又叫作最少知識原則(Law of Demeter)

          該代碼只和與其有直接關(guān)系的部分連接。(比如:該部分繼承的類,包含的對象,參數(shù)傳遞的對象等)。

          15.避免過早優(yōu)化(Avoid Premature Optimization)

          除非你的代碼運行的比你想像中的要慢,否則別去優(yōu)化。假如你真的想優(yōu)化,就必須先想好如何用數(shù)據(jù)證明,它的速度變快了。

          “過早的優(yōu)化是一切罪惡的根源”——Donald Knuth

          16.代碼重用原則(Code Reuse is Good) 

          重用代碼能提高代碼的可讀性,縮短開發(fā)時間。

          17.關(guān)注點分離(Separation of Concerns)

          不同領(lǐng)域的功能,應(yīng)該由不同的代碼和最小重迭的模塊組成。

          18.擁抱改變(Embrace Change)

          這是Kent Beck一本書的標(biāo)題,同時也被認(rèn)為是極限編程和敏捷方法的宗旨。

          許多其他原則都是基于這個概念的,即你應(yīng)該積極面對變化。事實上,一些較老的編程原則如最小化耦合原則都是為了使代碼能夠容易變化。無論你是否是個極限編程者,基于這個原則去編寫代碼會讓你的工作變得更有意義。

          作者簡介:Christopher Diggins是加拿大一位有25年編程經(jīng)驗的資深技術(shù)人員,曾效力于Microsoft和AutoDesk,并創(chuàng)辦過兩家贏利的互聯(lián)網(wǎng)公司。

          他是《C++ Cookbook》的作者之一,并自己編寫了一門編程語言Heron。




          posted @ 2011-11-09 19:19 人稱小雨 閱讀(161) | 評論 (0)編輯 收藏
            2011年10月26日
              下面這段話是轉(zhuǎn)載的解釋:
               

           Singleton Pattern(單例模式)

           改善全局變量和命名空間的沖突,可以說是一種改良了的全局變量。這種一個類只有一個實例,且提供一個訪問全局點的方式,更加靈活的保證了實例的創(chuàng)建和訪問約束。
              有時候在使用類的時候,這個類必須存在,但是我們又要求這個類在整個工程中只能有一個對象,無論什么時候調(diào)用都只能調(diào)用這唯一的一個對象,怎么做呢?
              這種模式的核心跟javaBean有點類似,不同在于單例模式要求創(chuàng)建并私有化一個對象,同時私有化構(gòu)造方法,重寫構(gòu)造方法使其返回這個對象。為了能夠使用這個對象,我們在其中創(chuàng)建一個靜態(tài)的Get方法用來返回該對象。
              
              一般的我們會用兩種單例模式的方法,一個是延遲加載,又叫懶漢式,另一個是非延遲加載,又稱餓汗式。區(qū)別在于前者是在調(diào)用的時候才生成對象,而后者則是事先生成對象;方法區(qū)別在于是否把生成對象放入get方法(可以加入判斷如果該對象不存在就new一個,存在的話就返回該已存在的對象)。
              這種思想在很多地方都會使用,用同樣的思想我們可以解決更多的問題。

              23種模式想了解更多的話可以去谷歌看看。我們重點不是掌握幾種方法,而是駕馭這種思想,靈活使用這種方法。高內(nèi)聚,低耦合,在寫程序之前就要對整個過程了解很透徹,而不是邊寫邊想究竟該怎么布局。
              
                  

          posted @ 2011-10-26 12:57 人稱小雨 閱讀(145) | 評論 (0)編輯 收藏
            2011年10月23日
              今天見識了手機的NFC(近場感應(yīng)技術(shù))功能,確實給生活帶來了很大方便。可以想象,以后的門、窗、電腦、電視、空調(diào)、汽車……不久以后的商場甚至是taxi…… 只有想不到的,沒有用不到的。這技術(shù)也許并不新奇,但是手機的功能正在向更強、更新、更快發(fā)展,似乎所有的功能我們都想把它給予手機……也許以后手機就是披著手機外衣的“萬事通”。
              
              多態(tài),解釋為接口的多種不同實現(xiàn)方式式,但是并不是聲明為interface的接口類才能使用,不要被他迷惑了,我們就把它當(dāng)成一個抽象類,一個“稍微”特殊的類,用類的使用方法來使用它。
              首先,抽象類中沒有構(gòu)造方法,所以我們不能直接聲明它的對象,也就不能通過對象調(diào)用方法,但是它有至少一個子類,這就為我們留了一扇門。只要我們知道某個對象屬于它的子類(不必去知道究竟那個子類),我們就可以通過子類的對象調(diào)用方法。那么,究竟怎么知道那到底屬于那個子類呢?這就靠不同子類對抽象父類中這個方法的不同重寫來完成。那么,這句話是不是有點熟悉?對! 方法的重載跟這何其相似,不同的在于其“級別”不同:一個是自主判斷所屬子類而調(diào)用方法,一個是自主判斷不同參數(shù)調(diào)用方法。
              其次,就是對方法的調(diào)用了。當(dāng)父類指向子類,例如 Student stu = new littleStudent();  littleStudent 是抽象類Student的子類并且對Student的至少一個方法進行了重寫。那么當(dāng)我使用stu調(diào)用方法時,對于父類中有但是子類沒有重寫的方法,stu自動調(diào)用父類中的方法;而對于在子類中有重寫的方法,stu調(diào)用子類中的方法。
              我個人覺得在使用抽象類作為方法的參數(shù)或者返回值的時候,盡量不要使用Object,現(xiàn)在的省事兒也許就是以后自己或者別人的噩夢。 
              我堅持規(guī)范,開始不習(xí)慣或者郁悶很正常,這是對自己負責(zé),也是對別人負責(zé)。
              
              
              
          posted @ 2011-10-23 20:16 人稱小雨 閱讀(161) | 評論 (0)編輯 收藏
          僅列出標(biāo)題  
          主站蜘蛛池模板: 张北县| 乾安县| 山西省| 大兴区| 中阳县| 泽州县| 高邮市| 阳山县| 右玉县| 巍山| 镇江市| 南陵县| 新干县| 宜州市| 晴隆县| 台江县| 六盘水市| 岑巩县| 恭城| 汉阴县| 年辖:市辖区| 徐州市| 张北县| 蒙山县| 长乐市| 吴堡县| 太康县| 馆陶县| 崇州市| 突泉县| 澄迈县| 抚顺市| 大姚县| 竹北市| 丹江口市| 中阳县| 林口县| 吉首市| 雅安市| 荔浦县| 凤庆县|