ºÝºÝߣ

ºÝºÝߣShare a Scribd company logo
kRouter
https:/
/github.com/kelp404/kRouter
Kelp
github/kelp404!
iOS App Developer!
Front-end Developer!
Objective-C, CoffeeScript, Python
kRouter
Reason!
CoffeeScript!
kRouter!
Unit Test!
Conclusion
kRouter

SEO!
location.hash `#`
CoffeeScript
CoffeeScript
JavaScript
https:/
/github.com/madrobby/semicolon.js
CoffeeScript
JavaScript

}
}
}
}
CoffeeScript
JavaScript
return {
id: 1002? ,
name: ¡®Kelp¡¯?,
email: ¡®°ì±ð±ô±è°ª±è³ó²¹³Ù±ð.´Ç°ù²µ¡¯?
};
CoffeeScript

id: 1002?
name: ¡®Kelp¡¯?
email: ¡®°ì±ð±ô±è°ª±è³ó²¹³Ù±ð.´Ç°ù²µ¡¯?
JavaScript
function (members, name) {?
var result = [];?
for (var index = 0; index < members.length; index++) {?
if (members[index].name == name) {?
result.push(members[index]);?
}?
}?
return result;?
}
CoffeeScript

(members, name) ->
x for x in members when x.name is name
JavaScript
$(function () {
$(document).on(¡®click¡¯, ¡®#link¡¯, function () {
var s = $(¡®#text¡¯).text();
$(this).html(¡®Hello ¡® + s + ¡®!!¡¯);
});
});
CoffeeScript

$ ->
$(document).on ¡®click¡¯, ¡®#link¡¯, ->
s = $(¡®#text¡¯).text()
$(@).html ¡°Hello #{s}!!¡±
JavaScript

angular.module(¡®app¡¯, [])
.controller(¡®HomeController¡¯, function ($scope) {
$scope.text = ¡®hello¡¯;
});
CoffeeScript

a = angular.module ¡®app¡¯, []
a.controller ¡®HomeController¡¯, ($scope) ->
$scope.text = ¡®hello¡¯
CoffeeScript

npm install -g coffee-script
kRouter

Routes!
history.pushState()!
window.onpopstate
kRouter
common.coffee!
directive.coffee!
module.coffee!
provider.coffee
common.coffee

getUri: (href=location.href) ->!
matchRoute: (url, routes) ->!
parseQueryString: (queryString) ->
directive.coffee

kr-view!
kr-go
module.coffee

angular.module 'kRouter', [?
'kRouter.provider', 'kRouter.directive'?
]
provider.coffee
$kRouterProvider.register = (name, args={}) ->!
routers: []!
state:?
current: {}?
params: {}!
go: (href, push=true) ->
Unit Test

Travis CI!
karma!
jasmine
Conclusion

npm install -g coffee-script!
git clone https:/
/github.com/kelp404/kRouter.git?
cd kRouter?
git submodule update --init
Ad

Recommended

KEY
Php resque
Chaitanya Kuber
?
KEY
Background Jobs with Resque
homanj
?
PPT
Open Source Saturday - How can I contribute to Ruby on Rails?
Pravin Mishra
?
PDF
Background processing with Resque
Nicolas Blanco
?
PDF
Tdc 2013 - Ecossistema Ruby
Fabio Akita
?
PDF
Building an API with Django and Django REST Framework
Christopher Foresman
?
PPTX
OWASP Nagpur Meet #3 Android RE
OWASP Nagpur
?
PDF
Real-time search in Drupal. Meet Elasticsearch
Alexei Gorobets
?
PDF
Reliable Python REST API (by Volodymyr Hotsyk) - Web Back-End Tech Hangout - ...
Innovecs
?
PDF
Maarten Balliauw "Indexing and searching NuGet.org with Azure Functions and S...
Fwdays
?
PPTX
Indexing and searching NuGet.org with Azure Functions and Search - .NET fwday...
Maarten Balliauw
?
PDF
Real-time search in Drupal with Elasticsearch @Moldcamp
Alexei Gorobets
?
PPT
Drupal and Elasticsearch
Nikolay Ignatov
?
PDF
[Srijan Wednesday Webinar] Easy Performance Wins for Your Rails App
Srijan Technologies
?
PDF
Mastering Grails 3 Plugins - Greach 2016
Alvaro Sanchez-Mariscal
?
PPTX
Capistrano - automate all the things
John Cleary
?
PDF
Celery for internal API in SOA infrastructure
Roman Imankulov
?
PPTX
Getting Started with Capistrano
LaunchAny
?
PDF
What's New in v2 - AnsibleFest London 2015
jimi-c
?
PDF
Designing net-aws-glacier
Workhorse Computing
?
PDF
Google App Engine With Java And Groovy
Ken Kousen
?
PDF
Web Operations101
Nell Shamrell-Harrington
?
PDF
[JCConf 2020] Óà Kotlin ¿çÈë Serverless ÊÀ´ú
Shengyou Fan
?
PDF
Rust, Redis, and Protobuf - Oh My!
Nell Shamrell-Harrington
?
PDF
Scaling up task processing with Celery
Nicolas Grasset
?
PPTX
Gohan
Nachi Ueno
?
PDF
¡°MPU+: A Transformative Solution for Next-Gen AI at the Edge,¡± a Presentation...
Edge AI and Vision Alliance
?
PDF
Connecting Data and Intelligence: The Role of FME in Machine Learning
Safe Software
?
PDF
Smarter Aviation Data Management: Lessons from Swedavia Airports and Sweco
Safe Software
?

More Related Content

What's hot (19)

PDF
Reliable Python REST API (by Volodymyr Hotsyk) - Web Back-End Tech Hangout - ...
Innovecs
?
PDF
Maarten Balliauw "Indexing and searching NuGet.org with Azure Functions and S...
Fwdays
?
PPTX
Indexing and searching NuGet.org with Azure Functions and Search - .NET fwday...
Maarten Balliauw
?
PDF
Real-time search in Drupal with Elasticsearch @Moldcamp
Alexei Gorobets
?
PPT
Drupal and Elasticsearch
Nikolay Ignatov
?
PDF
[Srijan Wednesday Webinar] Easy Performance Wins for Your Rails App
Srijan Technologies
?
PDF
Mastering Grails 3 Plugins - Greach 2016
Alvaro Sanchez-Mariscal
?
PPTX
Capistrano - automate all the things
John Cleary
?
PDF
Celery for internal API in SOA infrastructure
Roman Imankulov
?
PPTX
Getting Started with Capistrano
LaunchAny
?
PDF
What's New in v2 - AnsibleFest London 2015
jimi-c
?
PDF
Designing net-aws-glacier
Workhorse Computing
?
PDF
Google App Engine With Java And Groovy
Ken Kousen
?
PDF
Web Operations101
Nell Shamrell-Harrington
?
PDF
[JCConf 2020] Óà Kotlin ¿çÈë Serverless ÊÀ´ú
Shengyou Fan
?
PDF
Rust, Redis, and Protobuf - Oh My!
Nell Shamrell-Harrington
?
PDF
Scaling up task processing with Celery
Nicolas Grasset
?
PPTX
Gohan
Nachi Ueno
?
Reliable Python REST API (by Volodymyr Hotsyk) - Web Back-End Tech Hangout - ...
Innovecs
?
Maarten Balliauw "Indexing and searching NuGet.org with Azure Functions and S...
Fwdays
?
Indexing and searching NuGet.org with Azure Functions and Search - .NET fwday...
Maarten Balliauw
?
Real-time search in Drupal with Elasticsearch @Moldcamp
Alexei Gorobets
?
Drupal and Elasticsearch
Nikolay Ignatov
?
[Srijan Wednesday Webinar] Easy Performance Wins for Your Rails App
Srijan Technologies
?
Mastering Grails 3 Plugins - Greach 2016
Alvaro Sanchez-Mariscal
?
Capistrano - automate all the things
John Cleary
?
Celery for internal API in SOA infrastructure
Roman Imankulov
?
Getting Started with Capistrano
LaunchAny
?
What's New in v2 - AnsibleFest London 2015
jimi-c
?
Designing net-aws-glacier
Workhorse Computing
?
Google App Engine With Java And Groovy
Ken Kousen
?
Web Operations101
Nell Shamrell-Harrington
?
[JCConf 2020] Óà Kotlin ¿çÈë Serverless ÊÀ´ú
Shengyou Fan
?
Rust, Redis, and Protobuf - Oh My!
Nell Shamrell-Harrington
?
Scaling up task processing with Celery
Nicolas Grasset
?

Recently uploaded (20)

PDF
¡°MPU+: A Transformative Solution for Next-Gen AI at the Edge,¡± a Presentation...
Edge AI and Vision Alliance
?
PDF
Connecting Data and Intelligence: The Role of FME in Machine Learning
Safe Software
?
PDF
Smarter Aviation Data Management: Lessons from Swedavia Airports and Sweco
Safe Software
?
PPTX
UserCon Belgium: Honey, VMware increased my bill
stijn40
?
PDF
"Database isolation: how we deal with hundreds of direct connections to the d...
Fwdays
?
PDF
AI vs Human Writing: Can You Tell the Difference?
Shashi Sathyanarayana, Ph.D
?
PDF
Database Benchmarking for Performance Masterclass: Session 2 - Data Modeling ...
ScyllaDB
?
PPTX
OpenACC and Open Hackathons Monthly Highlights June 2025
OpenACC
?
PPTX
Security Tips for Enterprise Azure Solutions
Michele Leroux Bustamante
?
PDF
Quantum AI: Where Impossible Becomes Probable
Saikat Basu
?
PDF
Python Conference Singapore - 19 Jun 2025
ninefyi
?
PDF
9-1-1 Addressing: End-to-End Automation Using FME
Safe Software
?
PDF
Quantum AI Discoveries: Fractal Patterns Consciousness and Cyclical Universes
Saikat Basu
?
PDF
Coordinated Disclosure for ML - What's Different and What's the Same.pdf
Priyanka Aash
?
PDF
Raman Bhaumik - Passionate Tech Enthusiast
Raman Bhaumik
?
PPTX
Curietech AI in action - Accelerate MuleSoft development
shyamraj55
?
PDF
"Scaling in space and time with Temporal", Andriy Lupa.pdf
Fwdays
?
PDF
A Constitutional Quagmire - Ethical Minefields of AI, Cyber, and Privacy.pdf
Priyanka Aash
?
PPTX
Securing Account Lifecycles in the Age of Deepfakes.pptx
FIDO Alliance
?
PDF
Cracking the Code - Unveiling Synergies Between Open Source Security and AI.pdf
Priyanka Aash
?
¡°MPU+: A Transformative Solution for Next-Gen AI at the Edge,¡± a Presentation...
Edge AI and Vision Alliance
?
Connecting Data and Intelligence: The Role of FME in Machine Learning
Safe Software
?
Smarter Aviation Data Management: Lessons from Swedavia Airports and Sweco
Safe Software
?
UserCon Belgium: Honey, VMware increased my bill
stijn40
?
"Database isolation: how we deal with hundreds of direct connections to the d...
Fwdays
?
AI vs Human Writing: Can You Tell the Difference?
Shashi Sathyanarayana, Ph.D
?
Database Benchmarking for Performance Masterclass: Session 2 - Data Modeling ...
ScyllaDB
?
OpenACC and Open Hackathons Monthly Highlights June 2025
OpenACC
?
Security Tips for Enterprise Azure Solutions
Michele Leroux Bustamante
?
Quantum AI: Where Impossible Becomes Probable
Saikat Basu
?
Python Conference Singapore - 19 Jun 2025
ninefyi
?
9-1-1 Addressing: End-to-End Automation Using FME
Safe Software
?
Quantum AI Discoveries: Fractal Patterns Consciousness and Cyclical Universes
Saikat Basu
?
Coordinated Disclosure for ML - What's Different and What's the Same.pdf
Priyanka Aash
?
Raman Bhaumik - Passionate Tech Enthusiast
Raman Bhaumik
?
Curietech AI in action - Accelerate MuleSoft development
shyamraj55
?
"Scaling in space and time with Temporal", Andriy Lupa.pdf
Fwdays
?
A Constitutional Quagmire - Ethical Minefields of AI, Cyber, and Privacy.pdf
Priyanka Aash
?
Securing Account Lifecycles in the Age of Deepfakes.pptx
FIDO Alliance
?
Cracking the Code - Unveiling Synergies Between Open Source Security and AI.pdf
Priyanka Aash
?
Ad

kRouter