SlideShare a Scribd company logo
JavaScript Tools
       Wolfram Kriesing
       CTO, uxebu

       @wolframkriesing




Mittwoch, 18. April 12
Warming up: shorten please!	




                         http://140byt.es
Mittwoch, 18. April 12
Try it out? Any tool?

                           The Console!

                         Browser




                                          node.js
Mittwoch, 18. April 12
uxebu


        Technology                    100%


             Product

                            Flash          Bikeshed
                         - since 2008
           Company       - 10 People (in DE, NL, US, UK)
Mittwoch, 18. April 12
Agenda



       • TDD, CI, Build


       • IDE and features


       • Inspector (Firebug, Webkit Inspector)


       • Tools of the future (bikeshed editor)




Mittwoch, 18. April 12
TDD, CI, Build




Mittwoch, 18. April 12
Jasmine




       • JavaScript quasi standard


       • For nodejs+browser (server+client)


       • Built-in Spies




                                     http://pivotal.github.com/jasmine/

Mittwoch, 18. April 12
Jasmine - Matchers




Mittwoch, 18. April 12
Jasmine - Matchers, watch out!




Mittwoch, 18. April 12
Matchers - toContain, not




Mittwoch, 18. April 12
Custom Matchers - toBeInstanceOf




Mittwoch, 18. April 12
Custom Matchers - toBeInstanceOf




Mittwoch, 18. April 12
Custom Matchers




Mittwoch, 18. April 12
Custom Matchers




Mittwoch, 18. April 12
Spies



       • Decoupled Testing


       • Fast Tests (Removes waits, Removes timings)


       • Better Architecture


       • Async Testing




Mittwoch, 18. April 12
Spies




Mittwoch, 18. April 12
Spies




Mittwoch, 18. April 12
TDD is just the start...




Mittwoch, 18. April 12
Our Process



                                      Repo


                           Dev
                                               CI
                         All Devs


                                    Flowdock



Mittwoch, 18. April 12
CI - Continuous Integration

       • All projects


       • Automated Test runs (multiple browsers/devices)


       • Build


       • Code coverage


       • On Linux!




Mittwoch, 18. April 12
CI - Continuous Integration




                         http://siliconforks.com/jscoverage/
Mittwoch, 18. April 12
CI - Continuous Integration




Mittwoch, 18. April 12
Minify




                         Ping Response Time

                            On mobile!!!


Mittwoch, 18. April 12
Mittwoch, 18. April 12
Mittwoch, 18. April 12
Mittwoch, 18. April 12
Minifiers


                         http://code.google.com/intl/de-DE/closure/compiler/

                         https://github.com/mishoo/UglifyJS/

                         http://developer.yahoo.com/yui/compressor/

                         http://shrinksafe.dojotoolkit.org/

                         http://www.crockford.com/javascript/jsmin.html

                         ...



Mittwoch, 18. April 12
Compare




                         http://compressorrater.thruhere.net/


Mittwoch, 18. April 12
Google Closure




Mittwoch, 18. April 12
Google Closure




                         http://closure-compiler.appspot.com/home

Mittwoch, 18. April 12
Think different

Mittwoch, 18. April 12
http://140byt.es




Mittwoch, 18. April 12
IDE essentials (using WebStorm)




Mittwoch, 18. April 12
Embedded Jasmine Test Runner




                                          Test




                         Test Platforms          Result


Mittwoch, 18. April 12
Live Please :)




Mittwoch, 18. April 12
Hints - Unused Code




Mittwoch, 18. April 12
Hints - Trailing Commas




                           OK




                         Global


Mittwoch, 18. April 12
Hints - Others




Mittwoch, 18. April 12
Code Style




Mittwoch, 18. April 12
Rename



       • File (updates git, and „requires“)


       • Variables


       • Functions


       • Across Files




Mittwoch, 18. April 12
Refactor



       • Extract into Method


       • Extract Variable


       • Inline


       • Rewrite (if) Statements




Mittwoch, 18. April 12
Inspector




Mittwoch, 18. April 12
We want to know how it works on the inside!


Mittwoch, 18. April 12
Latest and Greatest




Mittwoch, 18. April 12
Console, please!




Mittwoch, 18. April 12
One Shortcut for All (Browsers)




Mittwoch, 18. April 12
monitorEvents(document.body)




Mittwoch, 18. April 12
Console



       • console.profile(), console.profileEnd()


       • console.dir()


       • console.time(), console.timeEnd()


       • console.trace()




Mittwoch, 18. April 12
*.toString()



       • function source


       • function parameters


       • even console.log.toString()




Mittwoch, 18. April 12
console.log.toString()




Mittwoch, 18. April 12
Fix in Place




Mittwoch, 18. April 12
Mittwoch, 18. April 12
Demo Time, Webkit Inspector Remote




Mittwoch, 18. April 12
Tools from the Future (and now)




Mittwoch, 18. April 12
Bikeshed Tooling

       • Instant Preview




                         Preview   Source
Mittwoch, 18. April 12
Bikeshed Tooling

                         Cursor




                                  API docs


                     Highlight
Mittwoch, 18. April 12
Bikeshed Tooling

       • Instant Preview

       • Auto completion

       • Embedded API docs

       • Intelligent Value Modifier




Mittwoch, 18. April 12
Bikeshed Tooling
    star                                           red
    polygon                                        green

                         Method          Color
    circle                                         blue
    rect                                           yellow
    ellipse                                        ...
    ...




                 Attribute   lineColor
                             lineWidth
                                                            1
                                                            2
                             fillColor                      3
                             filters
                             x                   Number     4
                                                            5
                             y                              ...
                             ...

Mittwoch, 18. April 12
Bikeshed Tooling



       • Instant Preview

       • Auto completion

       • Embedded API docs

       • Intelligent Value Modifier

       • All browser based




Mittwoch, 18. April 12
Editor Demo Time :)




Mittwoch, 18. April 12
Thank you

                         @bikeshedjs

                         Wolfram Kriesing, CTO
                         uxebu
                         @wolframkriesing




Mittwoch, 18. April 12

More Related Content

PDF
Rails I18n From The Trenches
DOCX
Los viajes del descubrimiento de america
PDF
Insan kaynaklari-egitimi
PPTX
Digi-pack
PDF
รวมรายงานเด๊๋ยวมัดPdf
PDF
Cyber security foss-foruniversities-haiphong-15042012
PPT
Trabajo alex galego
Rails I18n From The Trenches
Los viajes del descubrimiento de america
Insan kaynaklari-egitimi
Digi-pack
รวมรายงานเด๊๋ยวมัดPdf
Cyber security foss-foruniversities-haiphong-15042012
Trabajo alex galego

Similar to April JavaScript Tools (20)

PDF
The Restless Are Getting Native: SeleniumConf 2012
PDF
Internship dotCloud
PDF
Cloud Tech III: Actionable Metrics
PPTX
KubeSecOps
PDF
Phpday - Automated acceptance testing with Behat and Mink
PPTX
Programming Lecture 2nd - Flask and Heroku in Python -
PDF
The Cog VM evolution
PDF
Sencha Touch 2
PDF
Sencha Touch 2
PDF
Architecting for Change: QCONNYC 2012
PPTX
Alfresco Demo Data
PDF
Puppet Keynote
PDF
Triage: real-world error logging for web applications
PDF
Experiências, Erros e Acertos no Desenvolvimento de Projetos Ágeis
PDF
Is Your API Misbehaving (workshop)
PDF
Getting Started with C++ (TCF 2014)
PDF
Pigaios: A Tool for Diffing Source Codes against Binaries (Hacktivity 2018)
PDF
Agile 2008 Retrospective
PDF
JavaScript QA Tools
PDF
Engineering Change
The Restless Are Getting Native: SeleniumConf 2012
Internship dotCloud
Cloud Tech III: Actionable Metrics
KubeSecOps
Phpday - Automated acceptance testing with Behat and Mink
Programming Lecture 2nd - Flask and Heroku in Python -
The Cog VM evolution
Sencha Touch 2
Sencha Touch 2
Architecting for Change: QCONNYC 2012
Alfresco Demo Data
Puppet Keynote
Triage: real-world error logging for web applications
Experiências, Erros e Acertos no Desenvolvimento de Projetos Ágeis
Is Your API Misbehaving (workshop)
Getting Started with C++ (TCF 2014)
Pigaios: A Tool for Diffing Source Codes against Binaries (Hacktivity 2018)
Agile 2008 Retrospective
JavaScript QA Tools
Engineering Change
Ad

More from wolframkriesing (20)

PDF
JavaScript The Language Meetup - Async functions
PDF
Our react-native experiences at crewmeister
PDF
ES6 katas - talk given at enterjs
PDF
TDD for Kids - VLCjs (Valencia Spain, July 2015)
PDF
ES6Katas.org - an introduction and the story behind
PDF
TDD with Google Spreadsheets #enterjs 2015
PDF
Baby steps
PDF
TDD with Google Spreadsheets
PDF
ECMAScript 6 for real
PDF
Refactoring out of the mess
PDF
Day2 - Refactoring (Lecture SS 2015)
PDF
Day1 - TDD (Lecture SS 2015)
PDF
react.js - DOM as it was meant
PDF
Pixelplant - WebDev Meetup Salzburg
PDF
Better Code through TDD
PDF
Presentation Mobile Monday Munich, March 2012
PDF
Webtestsuite black berrydevcon
PDF
PDF
JavaScript Tools (PHPConference 2011, Berlin)
JavaScript The Language Meetup - Async functions
Our react-native experiences at crewmeister
ES6 katas - talk given at enterjs
TDD for Kids - VLCjs (Valencia Spain, July 2015)
ES6Katas.org - an introduction and the story behind
TDD with Google Spreadsheets #enterjs 2015
Baby steps
TDD with Google Spreadsheets
ECMAScript 6 for real
Refactoring out of the mess
Day2 - Refactoring (Lecture SS 2015)
Day1 - TDD (Lecture SS 2015)
react.js - DOM as it was meant
Pixelplant - WebDev Meetup Salzburg
Better Code through TDD
Presentation Mobile Monday Munich, March 2012
Webtestsuite black berrydevcon
JavaScript Tools (PHPConference 2011, Berlin)
Ad

Recently uploaded (20)

PPTX
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PPTX
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
PDF
Network Security Unit 5.pdf for BCA BBA.
PDF
Spectral efficient network and resource selection model in 5G networks
PDF
Per capita expenditure prediction using model stacking based on satellite ima...
PPTX
MYSQL Presentation for SQL database connectivity
PDF
Electronic commerce courselecture one. Pdf
PPTX
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
PDF
Modernizing your data center with Dell and AMD
PPTX
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
PDF
NewMind AI Weekly Chronicles - August'25 Week I
PDF
Encapsulation theory and applications.pdf
PPTX
Big Data Technologies - Introduction.pptx
PDF
Encapsulation_ Review paper, used for researhc scholars
PDF
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
Diabetes mellitus diagnosis method based random forest with bat algorithm
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
Network Security Unit 5.pdf for BCA BBA.
Spectral efficient network and resource selection model in 5G networks
Per capita expenditure prediction using model stacking based on satellite ima...
MYSQL Presentation for SQL database connectivity
Electronic commerce courselecture one. Pdf
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
Modernizing your data center with Dell and AMD
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
NewMind AI Weekly Chronicles - August'25 Week I
Encapsulation theory and applications.pdf
Big Data Technologies - Introduction.pptx
Encapsulation_ Review paper, used for researhc scholars
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
Building Integrated photovoltaic BIPV_UPV.pdf
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
Digital-Transformation-Roadmap-for-Companies.pptx

April JavaScript Tools