91成人精品,神马影院东京干,国产一级做a爰片久久 亚洲日韩欧美一区二区三区_国产AV无码专区亚洲AV

首頁

Spring 5 新特性:函數(shù)式Web框架

藍藍設計的小編

舉例

我們先從示例應用程序的一些摘錄開始。下面是暴露Person對象的響應信息庫。很類似于傳統(tǒng)的,非響應信息庫,只不過它返回Flux<Person>而傳統(tǒng)的返回List<Person>,以及返回Mono<Person>的地方返回Person。Mono<Void>用作完成標識:指出何時保存被完成。關于Reactor類型的更多信息,請參閱

public interface PersonRepository { Mono<Person> getPerson(int id); Flux<Person> allPeople(); Mono<Void> savePerson(Mono<Person> person);
}

下面是我們如何暴露帶有新的函數(shù)式web框架的資源庫:

RouterFunction<?> route = route(GET("/person/{id}"),
    request -> {
        Mono<Person> person = Mono.justOrEmpty(request.pathVariable("id"))
            .map(Integer::valueOf)
            .then(repository::getPerson); return Response.ok().body(fromPublisher(person, Person.class));
    })
    .and(route(GET("/person"),
        request -> {
            Flux<Person> people = repository.allPeople(); return Response.ok().body(fromPublisher(people, Person.class));
    }))
    .and(route(POST("/person"),
    request -> {
        Mono<Person> person = request.body(toMono(Person.class)); return Response.ok().build(repository.savePerson(person));
}));

下面我們要介紹如何運行,比如在Reactor Netty中:

詳解 javascript 的類

藍藍設計的小編

前言

生活有度,人生添壽。

Javascript從當初的一個“彈窗語言”,一步步發(fā)展成為現(xiàn)在前后端通吃的龐然大物。javascript的受歡迎程度也是與日俱增,今年編程語言又是花落javascript,這實在是一個充滿了活力的語言。如今,隨隨便一個網頁javascript代碼量都不下數(shù)千行,要是node后端那更不止幾千行了。(WTF)代碼量的增加給編程帶來的首要的問題就是如何去編寫和維護如此龐大的代碼呢?答案就是模塊化思想,其實就是面向對象(OOP)編程,如今比較流行的三大前端框架(angular,react,vue)基本都實現(xiàn)了組件化編程,但組件化和我們所說的模塊化又有所不同,應該可以這么理解,組件化是模塊化的升級版,模塊化是組件化的基礎。那么,問題來了,javascript怎么面向對象編程呢?我想這很多老鳥也不定說的清楚吧,前端雜而活躍的各種社區(qū),很多前端er一度依賴各種插件,根本不需要去了解這些深層的東西卻照樣能完成任務。但我想作為一個有追求的前端er還是很有必要去學習這些看似用不著的東西的,別的不說,就單單因為我們是前端er,只會用jquery一個稍微厲害的后端都能代替你。好吧,廢話不多說,到底如何面向對象coding呢…..

很不幸,es5中并沒有給出明確的定義‘類’的概念,所以傳統(tǒng)的面向對象編程似乎是行不通的,那么又該腫么辦呢?值得慶幸的是,前輩們通過不斷探索總結,成功的用javascript模擬出了“類”。那么,javascript的類又該怎么定義呢?

在面向對象編程中,類(class)是對象(object)的模板,定義了同一組對象(又稱”實例”)共有的屬性和方法。

深入了解font-weight

藍藍設計的小編

1.jpg

問題提出

font-weight的屬性值有100、200、300、400、500、600、700、800、900和normal、bold、lighter、bolder,它們的區(qū)別是?
另外,在實際開發(fā)中,我們應該使用數(shù)值表達還是文字表達呢?

認識font-weight

根據W3C Fonts節(jié)章的規(guī)范標準,可知:

一起理解Virtual DOM

藍藍設計的小編

前言

React 好像已經火了很久很久,以致于我們對于 Virtual DOM 這個詞都已經很熟悉了,網上也有非常多的介紹 React、Virtual DOM 的文章。但是直到前不久我專門花時間去學習 Virtual DOM,才讓我對 Virtual DOM 有了一定的理解,以致于要懷疑起很久之前看過的那些文章來。倒不是這些文章講得不對,而是現(xiàn)在在我看來角度不太好,說得越多,越說不清。

讓我能夠有所開竅(自認為)的,是這篇文章:


Change And Its Detection In JavaScript Frameworks
Monday Mar 2, 2015 by Tero Parviainen


作者看問題的角度很棒,從數(shù)據變更與UI同步的角度來介紹各個典型框架,特別是對于 React 的 Virtual DOM,從這個角度理解起來更容易些。

了解并使用CSS中的rem單位

藍藍設計的小編

什么是 rem

可能在你使用收音機或者用其他音樂播放器之前,就已經聽過“R.E.M.”這個詞了。在這個樂隊眼中,這個詞是“淺睡眠時眼球的快速轉動”的縮寫,而在 css 中,rem 代表著“以根元素為參照物的 em 單位“。他不會讓你拋棄你的宗教信仰也不會讓你相信那個遠在月球的人,但是它可以幫助你實現(xiàn)一個和諧、平穩(wěn)的設計。

根據 W3C 規(guī)范中對 1rem 的定義:

1rem 與等于根元素 font-size 的計算值。當明確規(guī)定根元素的 font-size 時,rem 單位以該屬性的初始值作參照。

Web服務器、應用程序服務器、HTTP服務器區(qū)別

藍藍設計的小編

WEB服務器、應用程序服務器、HTTP服務器有何區(qū)別?IIS、Apache、Tomcat、Weblogic、WebSphere 都各屬于哪種服務器?這些問題困惑了很久,今天終于梳理清楚了:

Web服務器的基本功能就是提供Web信息瀏覽服務。它只需支持HTTP協(xié)議、HTML文檔格式及URL。與客戶端的網絡瀏覽器配合。因為Web服務器主要支持的協(xié)議就是HTTP,所以通常情況下HTTP服務器和WEB服務器是相等的(有沒有支持除HTTP之外的協(xié)議的web服務器,作者沒有考證過),說的是一回事。

應用程序服務器(簡稱應用服務器),我們先看一下微軟對它的定義:”我們把應用程序服務器定義為“作為服務器執(zhí)行共享業(yè)務應用程序的底層的系統(tǒng)軟件”。 就像文件服務器為很多用戶提供文件一樣,應用程序服務器讓多個用戶可以同時使用應用程序(通常是客戶創(chuàng)建的應用程序)”

通俗的講,Web服務器傳送(serves)頁面使瀏覽器可以瀏覽,然而應用程序服務器提供的是客戶端應用程序可以調用(call)的方法(methods)。確切一點,你可以說:Web服務器專門處理HTTP請求(request),但是應用程序服務器是通過很多協(xié)議來為應用程序提供(serves)商業(yè)邏輯 (business logic)。

JavaScript 中對象的深拷貝

藍藍設計的小編

在JavaScript中,對對象進行拷貝的場景比較常見。但是簡單的復制語句只能對對象進行淺拷貝,即復制的是一份引用,而不是它所引用的對象。而更多的時候,我們希望對對象進行深拷貝,避免原始對象被無意修改。

對象的深拷貝與淺拷貝的區(qū)別如下:

  • 淺拷貝:僅僅復制對象的引用,而不是對象本身;
  • 深拷貝:把復制的對象所引用的全部對象都復制一遍。

一. 淺拷貝的實現(xiàn)

淺拷貝的實現(xiàn)方法比較簡單,只要使用是簡單的復制語句即可。

1.1 方法一:簡單的復制語句

/* ================ 淺拷貝 ================ */ function simpleClone(initalObj) { var obj = {}; for ( var i in initalObj) {
        obj[i] = initalObj[i];
    } return obj;
}

JavaScript世界萬物誕生記

藍藍設計的小編

一. 無中生有

起初,什么都沒有。

1.png

 

造物主說:沒有東西本身也是一種東西啊,于是就有了null:

現(xiàn)在我們要造點兒東西出來。但是沒有原料怎么辦?

有一個聲音說:不是有null嘛?

另一個聲音說:可是null代表無啊。

造物主說:那就無中生有吧!

于是:

2.png

更快學習JS的6個簡單思維技巧

藍藍設計的小編

當人們嘗試學習 JavaScript , 或者其他編程技術的時候,常常會遇到同樣的挑戰(zhàn):

  • 有些概念容易混淆,特別是當你學習過其他語言的時候。
  • 很難找到學習的時間(有時候是動力)。
  • 一旦當你理解了一些東西的時候,卻很容易再一次忘記。
  • 可以使用的工具甚多且經常變化,所以不知道從哪里開始入手。

幸運的是,這些挑戰(zhàn)最終都可以被戰(zhàn)勝。在這篇文章里,我將介紹 6 個思維技巧來幫你更快的學習 JavaScript ,讓你成為一個更快樂更多產的程序員。

對于很多學習 JavaScript 的人來說,他們問的第一個問題是選用哪個框架(現(xiàn)有框架非常多)。但是如果你還不熟悉原生的 JavaScript ,那這就是個不該問的問題。你會花費你全部的時間去查詢不同的框架并且不會取得任何進展。

詳解JS 變量、作用域及內存

藍藍設計的小編

基本類型值有:undefined,NUll,Boolean,Number和String,這些類型分別在內存中占有固定的大小空間,他們的值保存在??臻g,我們通過按值來訪問的。

 

1)值類型:數(shù)值、布爾值、null、undefined
2)引用類型:對象、數(shù)組、函數(shù)。
 
如果賦值的是引用類型的值,則必須在堆內存中為這個值分配空間。由于這種值的大小不固定(對象有很多屬性和方法),因此不能把他們保存到棧內存中。但內存地址大小是固定的,因此可以將內存地址保存在棧內存中。
 
<script type="text/javascript”>
var box = new Object();  //創(chuàng)建一個引用類型
var box = "trigkit4";   //基本類型值是字符串
box.age = 21;    //基本類型值添加屬性很怪異,因為只有對象才可以添加屬性。
alert(box.age);  //不是引用類型,無法輸出;
</script>
 

日歷

鏈接

個人資料

藍藍設計的小編 http://www.b186.net

存檔