2000或2001年以前在美國,是Sun的HotSpot JDK的主力開發(fā)之一
創(chuàng)新互聯(lián)10多年成都定制網(wǎng)站服務(wù);為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計及高端網(wǎng)站定制服務(wù),成都定制網(wǎng)站及推廣,對成都石涼亭等多個方面擁有豐富的網(wǎng)站制作經(jīng)驗的網(wǎng)站建設(shè)公司。
回到丹麥,2002年創(chuàng)立OOVM。因為他對Smalltalk的熱愛,OOVM被寫成一個以Smalltalk為開發(fā)語言的迷你虛擬機,主打各種資源有限嵌入式設(shè)備,代碼調(diào)試、熱部署、熱替換都很方便。沒記錯的話當時宣傳是最低128K RAM就可以運行。
OOVM在2004年被當時J2ME VM的主要開發(fā)商Esmertec收購,后來改名為OSVM,以突出其能夠在bare metal上運行的特性。
Lars Bak的家是個丹麥的農(nóng)場,有時候高層開會就跑去他家里開...
2006年因為經(jīng)濟不景氣,同時OSVM始終沒能在市場上取得大的進展(一方面原因是Smalltalk還是太小眾了),Esmertec關(guān)掉了位于丹麥的OSVM分支。
Lars Bak隨后加入Google。這里Wikipedia上的記載有誤,他是在06年而不是04年加入Google從事V8開發(fā)的。
目前隨著科技的發(fā)展,國家的進步,各行各樣涌現(xiàn)出了許許多多的人才與前段開發(fā)牛人
今天就介紹一些行業(yè)的前段開發(fā)牛人
avaScript語言:周愛民、老趙、玉伯、hax,月影、CatChen, winter, 白露飛 等等
DOM 和瀏覽器兼容性:winter, 司徒正美、屈超、懌飛 等等
HTML 和 CSS:彪叔、aoao, 懌飛、macji 等等
類庫框架:玉伯、JK, cnberg, yiminghe, 元彥 等等
前端布道士:克軍、玉伯、懌飛、秦歌、小馬 等等
不知分到哪一類的:hujinpu, 李牧、winter,dexteryy, 李超、老魚、太伯、陳成 等等一堆人
百度的玉北,GrayZhang,攜程的大漠,林小志,前段亂燉的芋頭
云適配的陳本峰 javascript還有一個不會營銷的大牛,席新亮,是很多群的群主,天天回答js問題,不過很少在論壇和博客上看到它。土豆前端開發(fā)工程師:西點王子-知乎
知乎專欄:web前端開發(fā)知乎專欄目
《鋒利的jquery 作者》 - 單東林。不敢說多牛,但是是我敬佩的師傅。
林小志大神。從小看《css那些事兒》長大的
:還有#@just.jayac到他的關(guān)于頁面,很有Geek風(fēng)格總之,現(xiàn)在的前段牛人各行各業(yè)都有很多了。不僅僅只是限于騰訊與淘寶的科技開發(fā)人員了。更多的活躍于flash與游戲領(lǐng)域。只要大家多多發(fā)掘,也可以認識許許多多的牛人大神。
javascript:document.write( (11.3-10.1).toFixed(2) )
toFixed()方法不僅僅截去多余的小數(shù)位,同時它還根據(jù)截取位置的下一個小數(shù)位進行四舍五入。例如,對于數(shù)值10.739,截取到小數(shù)點后的兩位數(shù),結(jié)果將是10.74。而對于數(shù)值10.732,截取到小數(shù)點后的兩位數(shù),結(jié)果將是10.73。
注意,在JavaScript中我們只能截取小數(shù)點之后0位~20位的小數(shù)。
toFixed()方法僅被高版本的瀏覽器所支持,所以在使用之前最好先檢查一下瀏覽器是否支持該方法,檢查的代碼如下所示:
var varNumber = 22.234;
if (varNumber.toFixed)
{
varNumber = varNumber.toFixed(2);
}
else //瀏覽器不支持toFixed()就使用其他方法
{
var div = Math.pow(10,2);
varNumber = Math.round(varNumber * div) / div;
}
這樣可以解決,但你想問,怎么可能多出這么小數(shù)點出來。
為什么會出現(xiàn)如此無法理解的答案?
我Google了一下,發(fā)現(xiàn)原來這是JavaScript浮點運算的一個bug。
比如:7*0.8 JavaScript算出來就是:5.6000000000000005
網(wǎng)上找到了一些解決辦法,就是重新寫了一些浮點運算的函數(shù)。
下面就把這些方法摘錄下來,以供遇到同樣問題的朋友參考:
程序代碼
//除法函數(shù),用來得到精確的除法結(jié)果
//說明:javascript的除法結(jié)果會有誤差,在兩個浮點數(shù)相除的時候會比較明顯。這個函數(shù)返回較為精確的除法結(jié)果。
//調(diào)用:accDiv(arg1,arg2)
//返回值:arg1除以arg2的精確結(jié)果
function accDiv(arg1,arg2){
var t1=0,t2=0,r1,r2;
try{t1=arg1.toString().split(".")[1].length}catch(e){}
try{t2=arg2.toString().split(".")[1].length}catch(e){}
with(Math){
r1=Number(arg1.toString().replace(".",""))
r2=Number(arg2.toString().replace(".",""))
return (r1/r2)*pow(10,t2-t1);
}
}
//給Number類型增加一個div方法,調(diào)用起來更加方便。
Number.prototype.div = function (arg){
return accDiv(this, arg);
}
//乘法函數(shù),用來得到精確的乘法結(jié)果
//說明:javascript的乘法結(jié)果會有誤差,在兩個浮點數(shù)相乘的時候會比較明顯。這個函數(shù)返回較為精確的乘法結(jié)果。
//調(diào)用:accMul(arg1,arg2)
//返回值:arg1乘以arg2的精確結(jié)果
function accMul(arg1,arg2)
{
var m=0,s1=arg1.toString(),s2=arg2.toString();
try{m+=s1.split(".")[1].length}catch(e){}
try{m+=s2.split(".")[1].length}catch(e){}
return Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m)
}
//給Number類型增加一個mul方法,調(diào)用起來更加方便。
Number.prototype.mul = function (arg){
return accMul(arg, this);
}
//加法函數(shù),用來得到精確的加法結(jié)果
//說明:javascript的加法結(jié)果會有誤差,在兩個浮點數(shù)相加的時候會比較明顯。這個函數(shù)返回較為精確的加法結(jié)果。
//調(diào)用:accAdd(arg1,arg2)
//返回值:arg1加上arg2的精確結(jié)果
function accAdd(arg1,arg2){
var r1,r2,m;
try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}
try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}
m=Math.pow(10,Math.max(r1,r2))
return (arg1*m+arg2*m)/m
}
//給Number類型增加一個add方法,調(diào)用起來更加方便。
Number.prototype.add = function (arg){
return accAdd(arg,this);
}
在你要用的地方包含這些函數(shù),然后調(diào)用它來計算就可以了。
比如你要計算:7*0.8 ,則改成 (7).mul(8)
其它運算類似,就可以得到比較精確的結(jié)果。
--------------------------------------------------------------------------
以上是在網(wǎng)上一個JS牛人的博客上轉(zhuǎn)載的,不過上面只提及了加法、乘法和除法的解決辦法。
這個時候可能很多人就會想,有了加法,減法還不容易?我就是差點讓這個想法給害苦了。
其他的就不多說了,帖出減法的代碼:
function Subtr(arg1,arg2){
var r1,r2,m,n;
try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}
try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}
m=Math.pow(10,Math.max(r1,r2));
//last modify by deeka
//動態(tài)控制精度長度
n=(r1=r2)?r1:r2;
return ((arg1*m-arg2*m)/m).toFixed(n);
}
session是服務(wù)器端的ASP內(nèi)置對象,客戶端JavaScript判斷不了,不妨用cookie
從0基礎(chǔ)到勉強能用,只求入門的話2-3個月綽綽有余,但是要精通的話肯定是需要花更多時間日積月累了,選擇培訓(xùn)的話是要參與一些項目聯(lián)練習(xí)的,因為JavaScript很多技巧不通過項目這樣比較大的歷練是用不上的。千鋒官網(wǎng)每日更新最新軟件開發(fā)基礎(chǔ)知識內(nèi)容,鞏固日常學(xué)習(xí)中的基礎(chǔ)技能。更有免費的軟件開發(fā)視頻教程幫助學(xué)員快速學(xué)習(xí)。 千鋒教育就有線上免費的軟件開發(fā)公開課,。
Web前端培訓(xùn)多長時間,只能說簡單入門在五到六個月,真正要達到精通級別的話,需要天賦跟經(jīng)驗的積累。正所謂,一入前端深似海,從此回首無邊界。活到老,學(xué)到老。只要步入了前端開發(fā)你就會發(fā)現(xiàn),前端真的是要一直不停的學(xué),不停的學(xué)。千鋒教育集團目前已與國內(nèi)4000多家企業(yè)建立人才輸送合作,與500多所大學(xué)建立實訓(xùn)就業(yè)合作,每年為各大企業(yè)輸送上萬名移動開發(fā)工程師,每年有數(shù)十萬名學(xué)員受益于千鋒教育組織的技術(shù)研討會、技術(shù)培訓(xùn)課、網(wǎng)絡(luò)公開課及免費教學(xué)視頻。
說實話,不好學(xué),沒HTMl基礎(chǔ)有點難度,JavaScript簡稱JS,之前的基礎(chǔ)就是HTML,HTML這門課程如果入門的話不是很難,刻苦點一月到兩月就能搞定,有HTML基礎(chǔ)的話,只要繼續(xù)刻苦一個月左右JS就能入門,但是想學(xué)到高深那就不容易了,js入門后在繼續(xù)學(xué)可以說也是有些難度的??傊日莆誋TML,這是一個基礎(chǔ),正如你說話要先從aoe開始一樣,HTML也很容易學(xué)的
HTML推薦書籍:深入淺出HTML和CSS
JS推薦書籍:《javascript入門經(jīng)典》
這些書籍可以幫助你怎么學(xué)習(xí),其實不止看書,你也可以看看視頻,多看視頻講解學(xué)習(xí)可以讓你少走很多彎路,節(jié)省不少時間。遇見問題,常百度一下,現(xiàn)在百度只有你想不到的,沒有你查不到的,沒有你要的答案,也能查到相關(guān)的,何況可以提問嘛……
人就是在不斷的問題中解決問題,發(fā)現(xiàn)新的問題,繼續(xù)解決問題,這樣自己的自學(xué)能力和技術(shù)能夠得到很大的提升,關(guān)鍵就是不懂一定馬上問,千萬不要隨便拖,這樣進步才叫快……
還有補充一下,學(xué)習(xí)重在實踐,因為只有實踐你才能更好的發(fā)現(xiàn)自己的問題,一個問題解決了,一次不記得,下次繼續(xù)做的時候再手打一次,但是別抄之前自己寫過的代碼,除非你覺得自己這段代碼已經(jīng)掌握了,這樣為了節(jié)省時間才抄,否則還是練練手最好,,萬變不離其宗——熟能生巧……
如果你精通了,那就好辦了,一個網(wǎng)站可能就被你開發(fā)出來,然后就不愁找不到好工作了,至于你認為學(xué)到什么地步算精通,這你自己在學(xué)習(xí)中就可以感受到自己的能力,說的夠多了,一時說不完,就這樣,最后祝你成功,嘎嘎嘎嘎……