Enviar búsqueda
Cargar
KISSY for starter
•
1 recomendación
•
751 vistas
yiming he
Seguir
Tecnología
Denunciar
Compartir
Denunciar
Compartir
1 de 96
Descargar ahora
Descargar para leer sin conexión
Recomendados
Web设计 4 锋利的j_query(进入企业级应用阶段)
Web设计 4 锋利的j_query(进入企业级应用阶段)
ziggear
JQuery 学习
JQuery 学习
cssrain
编辑器设计Kissy editor
编辑器设计Kissy editor
taobao.com
KISSY Mechanism
KISSY Mechanism
lifesinger
Kind editor设计思路
Kind editor设计思路
taobao.com
AJAX Basic
AJAX Basic
Ryan Chung
Node getting-started
Node getting-started
lylijincheng
编辑器设计U editor
编辑器设计U editor
taobao.com
Recomendados
Web设计 4 锋利的j_query(进入企业级应用阶段)
Web设计 4 锋利的j_query(进入企业级应用阶段)
ziggear
JQuery 学习
JQuery 学习
cssrain
编辑器设计Kissy editor
编辑器设计Kissy editor
taobao.com
KISSY Mechanism
KISSY Mechanism
lifesinger
Kind editor设计思路
Kind editor设计思路
taobao.com
AJAX Basic
AJAX Basic
Ryan Chung
Node getting-started
Node getting-started
lylijincheng
编辑器设计U editor
编辑器设计U editor
taobao.com
Script with engine
Script with engine
Webrebuild
Sina App Quick Guide 1
Sina App Quick Guide 1
guestf4aed35
Node分享 展烨
Node分享 展烨
tb-vertical-guide
jQuery 選取器解析
jQuery 選取器解析
Kingsley Zheng
编辑器设计2
编辑器设计2
yiming he
前端MVVM框架安全
前端MVVM框架安全
Borg Han
Backbone js and requirejs
Backbone js and requirejs
Chi-wen Sun
浅析浏览器解析和渲染
浅析浏览器解析和渲染
Ailsa126
Kindeditor设计思路v2
Kindeditor设计思路v2
luolonghao
Web Caching Architecture and Design
Web Caching Architecture and Design
Ho Kim
第三方内容开发最佳实践
第三方内容开发最佳实践
taobao.com
Ooredis
Ooredis
iammutex
02 Objective-C
02 Objective-C
Tom Fan
Javascript
Javascript
Ryan Chung
Underscore
Underscore
cazhfe
用Jquery实现拖拽层
用Jquery实现拖拽层
yiditushe
Node.js在淘宝的应用实践
Node.js在淘宝的应用实践
taobao.com
J Query Learn
J Query Learn
guestfb42fc
MongoDB Basic
MongoDB Basic
simplels
Kissy editor开发与设计
Kissy editor开发与设计
yiming he
面向未来的前端类库开发 — KISSY 类库构想与实践
面向未来的前端类库开发 — KISSY 类库构想与实践
taobao.com
Kissy模块化实践
Kissy模块化实践
yiming he
Más contenido relacionado
La actualidad más candente
Script with engine
Script with engine
Webrebuild
Sina App Quick Guide 1
Sina App Quick Guide 1
guestf4aed35
Node分享 展烨
Node分享 展烨
tb-vertical-guide
jQuery 選取器解析
jQuery 選取器解析
Kingsley Zheng
编辑器设计2
编辑器设计2
yiming he
前端MVVM框架安全
前端MVVM框架安全
Borg Han
Backbone js and requirejs
Backbone js and requirejs
Chi-wen Sun
浅析浏览器解析和渲染
浅析浏览器解析和渲染
Ailsa126
Kindeditor设计思路v2
Kindeditor设计思路v2
luolonghao
Web Caching Architecture and Design
Web Caching Architecture and Design
Ho Kim
第三方内容开发最佳实践
第三方内容开发最佳实践
taobao.com
Ooredis
Ooredis
iammutex
02 Objective-C
02 Objective-C
Tom Fan
Javascript
Javascript
Ryan Chung
Underscore
Underscore
cazhfe
用Jquery实现拖拽层
用Jquery实现拖拽层
yiditushe
Node.js在淘宝的应用实践
Node.js在淘宝的应用实践
taobao.com
J Query Learn
J Query Learn
guestfb42fc
MongoDB Basic
MongoDB Basic
simplels
Kissy editor开发与设计
Kissy editor开发与设计
yiming he
La actualidad más candente
(20)
Script with engine
Script with engine
Sina App Quick Guide 1
Sina App Quick Guide 1
Node分享 展烨
Node分享 展烨
jQuery 選取器解析
jQuery 選取器解析
编辑器设计2
编辑器设计2
前端MVVM框架安全
前端MVVM框架安全
Backbone js and requirejs
Backbone js and requirejs
浅析浏览器解析和渲染
浅析浏览器解析和渲染
Kindeditor设计思路v2
Kindeditor设计思路v2
Web Caching Architecture and Design
Web Caching Architecture and Design
第三方内容开发最佳实践
第三方内容开发最佳实践
Ooredis
Ooredis
02 Objective-C
02 Objective-C
Javascript
Javascript
Underscore
Underscore
用Jquery实现拖拽层
用Jquery实现拖拽层
Node.js在淘宝的应用实践
Node.js在淘宝的应用实践
J Query Learn
J Query Learn
MongoDB Basic
MongoDB Basic
Kissy editor开发与设计
Kissy editor开发与设计
Similar a KISSY for starter
面向未来的前端类库开发 — KISSY 类库构想与实践
面向未来的前端类库开发 — KISSY 类库构想与实践
taobao.com
Kissy模块化实践
Kissy模块化实践
yiming he
Kissy design
Kissy design
yiming he
Mvc
Mvc
tbmallf2e
Dive into kissy
Dive into kissy
jay li
Html5和css3入门
Html5和css3入门
Xiujun Ma
Html5培训内容
Html5培训内容
Jun Yu
jQuery底层架构
jQuery底层架构
fangdeng
第十期 阿甘Javascript开发思想(入门篇)
第十期 阿甘Javascript开发思想(入门篇)
9scss
模块一-Go语言特性.pdf
模块一-Go语言特性.pdf
czzz1
前端测试
前端测试
frontwindysky
前端测试
前端测试
Zheng Biao
Javascript之昨是今非
Javascript之昨是今非
Tony Deng
Web development with zend framework
Web development with zend framework
thinkinlamp
PHP Coding Standard and 50+ Programming Skills
PHP Coding Standard and 50+ Programming Skills
Ho Kim
JavaScript 80+ Programming and Optimization Skills
JavaScript 80+ Programming and Optimization Skills
Ho Kim
KISSY Editor Design 2
KISSY Editor Design 2
yiming he
Kindeditor 设计思路
Kindeditor 设计思路
luolonghao
一拍一产品背后的故事(React实战)
一拍一产品背后的故事(React实战)
Kejun Zhang
使用Dsl改善软件设计
使用Dsl改善软件设计
mingjin
Similar a KISSY for starter
(20)
面向未来的前端类库开发 — KISSY 类库构想与实践
面向未来的前端类库开发 — KISSY 类库构想与实践
Kissy模块化实践
Kissy模块化实践
Kissy design
Kissy design
Mvc
Mvc
Dive into kissy
Dive into kissy
Html5和css3入门
Html5和css3入门
Html5培训内容
Html5培训内容
jQuery底层架构
jQuery底层架构
第十期 阿甘Javascript开发思想(入门篇)
第十期 阿甘Javascript开发思想(入门篇)
模块一-Go语言特性.pdf
模块一-Go语言特性.pdf
前端测试
前端测试
前端测试
前端测试
Javascript之昨是今非
Javascript之昨是今非
Web development with zend framework
Web development with zend framework
PHP Coding Standard and 50+ Programming Skills
PHP Coding Standard and 50+ Programming Skills
JavaScript 80+ Programming and Optimization Skills
JavaScript 80+ Programming and Optimization Skills
KISSY Editor Design 2
KISSY Editor Design 2
Kindeditor 设计思路
Kindeditor 设计思路
一拍一产品背后的故事(React实战)
一拍一产品背后的故事(React实战)
使用Dsl改善软件设计
使用Dsl改善软件设计
Más de yiming he
kissy 1.5 progress
kissy 1.5 progress
yiming he
kissy at alibaba
kissy at alibaba
yiming he
kissy modularization part2
kissy modularization part2
yiming he
kissy modularization part1
kissy modularization part1
yiming he
KISSY @ 2013-2
KISSY @ 2013-2
yiming he
KISSY 1.4.0 released
KISSY 1.4.0 released
yiming he
callSuper in kissy
callSuper in kissy
yiming he
KISSY XTemplate
KISSY XTemplate
yiming he
Introduction to kissy for adc 2013
Introduction to kissy for adc 2013
yiming he
Kissy component system
Kissy component system
yiming he
KISSY@2013.05
KISSY@2013.05
yiming he
kissy@2013.03
kissy@2013.03
yiming he
kissy@2013
kissy@2013
yiming he
KISSY 1.3-released
KISSY 1.3-released
yiming he
Simple kissy1.3
Simple kissy1.3
yiming he
Hujs 总结
Hujs 总结
yiming he
Kissy in-progress
Kissy in-progress
yiming he
Kissy dpl-practice
Kissy dpl-practice
yiming he
KISSY Component API Design
KISSY Component API Design
yiming he
Kissy autocomplete
Kissy autocomplete
yiming he
Más de yiming he
(20)
kissy 1.5 progress
kissy 1.5 progress
kissy at alibaba
kissy at alibaba
kissy modularization part2
kissy modularization part2
kissy modularization part1
kissy modularization part1
KISSY @ 2013-2
KISSY @ 2013-2
KISSY 1.4.0 released
KISSY 1.4.0 released
callSuper in kissy
callSuper in kissy
KISSY XTemplate
KISSY XTemplate
Introduction to kissy for adc 2013
Introduction to kissy for adc 2013
Kissy component system
Kissy component system
KISSY@2013.05
KISSY@2013.05
kissy@2013.03
kissy@2013.03
kissy@2013
kissy@2013
KISSY 1.3-released
KISSY 1.3-released
Simple kissy1.3
Simple kissy1.3
Hujs 总结
Hujs 总结
Kissy in-progress
Kissy in-progress
Kissy dpl-practice
Kissy dpl-practice
KISSY Component API Design
KISSY Component API Design
Kissy autocomplete
Kissy autocomplete
KISSY for starter
1.
常胤 & 承玉
2.
目的&目标 一.全面认识KISSY 二.KISSY的特点和优势 三.学会使用KISSY
3.
大纲 一.为什么使用KISSY 二.KISSY概况以及架构 三.KISSY快速上手
4.
Part1.为什么使用KISSY
5.
我们需要什么样的框架? 初级用户
中级用户 高级用户 表单验证 语言增强 扩展控件 自定义控 异步请求 DOM操作 件 UI组件 代码组织 ...
6.
我们需要什么样的框架? 1. 解决兼容性 2. 语言增强 3.
简单好记容易调用的API 4. Widget/component 5. 文档 6. 方便调试 7. 能帮我组织好代码 8. 不必为打包,部署烦劳
7.
现状 1. 都具备写前端代码的能力,但是会被兼 容性、合理性、性能等问题烦恼 2.
总感觉写的代码不是很好看 1. 过程式 2. 到处都是全局对象难维护 3. 代码到处散落 4. 复用性差
8.
YUI的问题 1. 高端 2. 上手慢 3.
维护难
9.
jquery的问题 1. 过于灵活 2. 缺少模块化方案 3.
团队规范结合难 4. 缺少统一全面的组件
10.
为什么使用KISSY
11.
为什么使用KISSY • 入门简单 •
API设计简单实用 • 组件贴近用户 • 支持 yui 和 jquery 两种语法,无缝切换 • 适合淘宝的JS类库 • 充分与基础设施融合 • 强大的“社区”支持 • 问题快速响应
12.
YUI-Like • var DOM
= KISSY.DOM; • var el = DOM.get(“#xx”); • DOM.css(el,”width”,100);
13.
Jquery-Like • var el
= KISSY.all(“#xx”); • el.css(”width”,100). parent(“.x”). end(). css(“height”,200);
14.
Part2.KISSY概况及架构
15.
16.
17.
Sub project •
Kissy-tools: 工具集合 • Kissy-util: 代码片段 • Kissy-dpl: 设计模式规范库 • Kissy-ajbridge: aj-js 桥梁 • Kissy-nodejs: kissy on nodejs
18.
Kissy tools
http://docs.kissyui.com/other/third.html#
19.
Kissy util
http://docs.kissyui.com/other/third.html#
20.
Kissy gallery
21.
Kissy dpl
22.
Kissy AJBridge
23.
Part3.KISSY快速上手
24.
<script src="http://a.tbcdn.cn/s/kissy/1.2.0/kissy.js"></script> <script>
KISSY.ready(function(S){ var $ = S.all; $("<p>hello world!</p>") .css({ color:"red" }) .appendTo(document.body); }) </script>
25.
常用功能介绍 •
seed • dom • event • anim • node • ajax
26.
seed
27.
语言增强 • isArray/isDate/isFunction/isObject/isNumb
er/isPlainObject • each/map/reduce/filter • inArray/indexOf/lastIndexOf/unique • substitute/trim/formUnicode • escapeHTML/unEscapeHTML/parseXML • Later/buffer/throttle
28.
前提准备 • mix:将一个对象的成员复制到另一个对象上 • merge:将多个对象的成员合并到新对象上. •
augment:复制prototype对象 • extend:函数继承 • namespace:创建命名空间 • log:调试信息 • error:异常错误 • guid:返回全局唯一 id.
29.
web • ready • globalEval/ •
available
30.
seed中的方法都是挂靠在KISSY命名空间下的,都 可以直接使用.
31.
demo
seed
32.
模块机制
33.
AMD
34.
模块注册 KISSY.add(function(S,DOM){
var d = DOM.get(“#id”); return { XX : YY }; },{ requires:[“dom”] });
35.
使用已有模块 KISSY.use(“switchable”,function(S, Switchable){
var t = new Switchable({….}); });
36.
包管理 KISSY.config({
packages:[ { // 包名 name:"tc", // 自动加上 ?t=20110323, 用于文件更新 tag:"20130323", // 包对应路径, 相对路径指相对于当前页面路径 path:"../", // 包里模块文件编码格式 charset:"gbk" } ] });
37.
demo loader
38.
DOM
39.
什么是DOM 文档对象模型(Document Object Model,简称 DOM),是W3C组织推荐的处理可扩展置标语言的标 准编程接口。通俗的讲:要改变页面的某个东西, JavaScript
就需要获得对 HTML 文档中所有元素进行 访问的入口。这个入口,连同对 HTML 元素进行添加、 移动、改变或移除的方法和属性,都是通过文档对象 模型来获得的(DOM)。 KISSY对DOM进行了进行了封装和扩展。
40.
selector KISSY 选择器内置仅支持 #id
tag.class 常用形式, 考虑 2/8 原则, 支持以下选择器: • #id • tag • .cls • #id tag • #id .cls • tag.cls • #id tag.cls
41.
selector // 获取符合选择器的所有元素.
KISSY.ready(function(S){ var els= S.DOM.query(“div"); }) // 获取符合选择器的第一个元素 KISSY.ready(function(S){ var el= S.DOM.get(“div"); })
42.
sizzle KISSY.use(“sizzle”,
function(S){ var $ = S.all; $('[class^=“test"]').hide(); }) http://www.codylindley.com/jquerysel ectors/
43.
class
• hasClass • addClass • removeClass • replaceClass • toggleClass
44.
常用操作 •
val:获取value 值. • text:获取元素所包含的文本值.相当于innerText • html:获取符合选择器的第一个元素的 innerHTML. • show:显示符合选择器的所有元素. • hide:隐藏符合选择器的所有元素. • toggle :显示隐藏
45.
DOM 节点遍历 •
parent:父节点. • next:下一个同级节点 • prev:上一个同级节点 • siblings:所有同级节点. • children:所有子节点.
46.
DOM 尺寸相关 •
width/height:高/宽. • innerWidth/innerHeight:包含padding • outerWidth/outerHeight:包含padding,margin,border 的宽/高 • scrollTop/scrollLeft:获取窗口或元素的 scrollTop/scrollLeft值. • docHeight/docWidth:获取document的高宽 • viewportHeight/viewportWidth :获取可视区的高宽
47.
DOM 节点修改 •
insertBefore • insertAfter • append • prepend
48.
DOM 属性/数据 •
attr:attributes • hasAttr • Prop:properties • hasProp • data:扩展属性 • removeData • hasData http://javascript.info/tutorial/attribute s-and-custom-properties
49.
Style & css •
addStyleSheet:将 cssText 字符串作为内 联样式添加到文档中. • style • css
50.
DOM中的方法在KISSY.DOM这个命名空间下
51.
demo DOM
52.
Event
53.
自定义事件 function MyClass(){
} KISSY.augment(MyClass,KISSY.EventTarget); var myObj = new MyClass(); myObj.on(“xx”,function(){ }); myObj.fire(“xx”);
54.
普通对象和 dom 节点一样也能触发,
添加和删除事 件.
55.
统一的注册方式 •
原生节点 – S.one(domNode).on(“click”,fn,context) • 自定义事件 – obj.on(“customEvent”,fn,context)
56.
统一的触发方式 •
Native event – S.one(domNode).fire(“click”) • Custom event – obj.fire(“customEvent”)
57.
事件兼容 •
submit/change @ie bubble, realtime fire • focusin/out @non-ie • mouseenter/leave @non-ie • hashchange @ie • mousewheel @firefox • valuechange @all
58.
Event中的方法在KISSY.Event这个命名空间下
59.
Event demo
60.
Anim
61.
var anim =
new KISSY.Anim( '#test', { 'width': '100px', 'left': '900px', 'opacity': '.5', 'font-size': '48px', 'color': '#FF3333' }, 5,//持续时间 'bounceOut',//动画平滑函数 function(){ alert('demo 结束'); }); anim.run();
62.
Anim demo
63.
64.
• Node 包括
dom , event , anim 模块的所 有功能, 推荐采用 Node 模块. • 只需要把 KISSY.all 看做 jquery 中的 $ //推荐用法 var $ = KISSY.all; $("#test").show();
65.
链式操作 KISSY.all(".cls")
.all("a") .css({"color":"red"}) .end() .all("p") .hide();
66.
创建节点 KISSY.all('<p class=“cls">test</p>')
.text(“test”) .appendTo(document.body);
67.
Dom 操作
node.height(300) .css({"color":"red"}) .addClass("cls") .attr("data-value","test");
68.
事件注册 node.on("click",fn); node.delegate("click","a",fn);
node.detach("click"); node.fire("click");
69.
动画 node.animate({left:"100px",top:"100px"}); node.stop(); node.stop(true); node.isRunning(); node.stop(true,true,queueName); node.slideToggle(); node.fadeToggle();
70.
Kissy IO
71.
XMLHttpRequest
KISSY.io({ url : "getJson.htm", cache : false, type : "get",// "post" data : { x: 1}, dataType : "json", // "text/html/xml" success : function(d){ }, error : function(_,reason){ }, complete : function(){ } });
72.
快捷方式 KISSY.io.get("test.php",function(d){
alert(d); }); KISSY.io.post("test.php",{ x : 3}, function(d){ alert(d); },"json");
73.
form 异步提交 KISSY.io({
<form id="formEl> url : "getJson.htm", <input name="f" type="file" /> type : "post", </form> data : {x: 1}, dataType : "json", form: "#formEl", success : function(d){ }, error : function(_,reason){ }, complete : function(){ } });
74.
跨域处理 跨域请求 – 跨子域 – 完全不同域
• 客户端透明 • 服务器端设置 CORS
75.
可中断请求
xhr.abort();
76.
组件库
77.
使用KISSY组件非常简单,与开发的习惯也很接近。 不需要再去head中显示插入script标签。
78.
overlay Demo
79.
在自己定义的模块中引入组件也非常简单。
80.
Drag&Drop
81.
switchable
82.
resizeable
83.
validation
84.
mvc
85.
Editor
86.
一致的调用方式
87.
gallery
88.
89.
90.
91.
92.
93.
94.
95.
KISSY
Biz mod mod Biz mod KISSY mod Page logic KISSY
96.
Gtalk/email:yiminghe@gmail.com 官方文档: http://docs.kissyui.com
Descargar ahora