# .toggle()
# .toggle()
Categories: [Effects](http://www.css88.com/jquery-ui-api/category/effects/ "View all posts in Effects") | [Effects Core](http://www.css88.com/jquery-ui-api/category/effects-core/ "View all posts in Effects Core") | [Method Overrides](http://www.css88.com/jquery-ui-api/category/overrides/ "View all posts in Method Overrides") | [Methods](http://www.css88.com/jquery-ui-api/category/methods/ "View all posts in Methods")
## .toggle( effect \[, options \] \[, duration \] \[, complete \] )Returns: [jQuery](http://api.jquery.com/Types/#jQuery)
**Description:** 使用自定义特效显示或隐藏匹配的元素。
- #### [.toggle( effect \[, options \] \[, duration \] \[, complete \] )](#toggle-effect-options-duration-complete)
- **effect**Type: [String](http://api.jquery.com/Types/#String)一个字符串,指示哪个[特效](category/effects)被使用。
- **options**Type: [Object](http://api.jquery.com/Types/#Object)特效选项和[缓冲函数](easings)。
- **duration** (default: `400`)Type: [Number](http://api.jquery.com/Types/#Number) or [String](http://api.jquery.com/Types/#String)一个字符串或者数字决定动画将运行多久。(愚人码头注:三种预定速度的字符串("slow", "normal", 或 "fast")或表示动画时长的毫秒数值(如:1000) )
- **complete**Type: [Function](http://api.jquery.com/Types/#Function)()在动画完成时执行的函数。
- #### [.toggle( options )](#toggle-options)
- **options**Type: [Object](http://api.jquery.com/Types/#Object)全部动画选项。 只有一个必须设置的属性`effect`。
- **effect**Type: [String](http://api.jquery.com/Types/#String)一个字符串,指示哪个[特效](category/effects)被使用。
- **easing** (default: `"swing"`)Type: [String](http://api.jquery.com/Types/#String)一个字符串,表示过渡使用哪种 [缓动 函数](easings)。
- **duration** (default: `400`)Type: [Number](http://api.jquery.com/Types/#Number) or [String](http://api.jquery.com/Types/#String)一个字符串或者数字决定动画将运行多久。(愚人码头注:三种预定速度的字符串("slow", "normal", 或 "fast")或表示动画时长的毫秒数值(如:1000) )
- **complete**Type: [Function](http://api.jquery.com/Types/#Function)()在动画完成时执行的函数。
- **queue** (default: `true`)Type: [Boolean](http://api.jquery.com/Types/#Boolean) or [String](http://api.jquery.com/Types/#String)一个布尔值,指示是否将动画放置在效果队列中。如果为false时,将立即开始动画。 **从jQuery1.7开始**,队列选项也可以接受一个字符串,在这种情况下, 在动画被添加到由该字符串表示的队列中。
这个插件扩展了jQuery中的[`.toggle()`](http://api.jquery.com/toggle)方法。 如果没有加载 jQuery UI,调用`.toggle()`方法可能不会失败,因为方法仍然存在。 然而,预期的行为(愚人码头注:指平滑过渡动画效果)将不会发生。
## Example:
#### 使用折叠特效来切换显示一个div。
```
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>toggle demo</title>
<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css">
<style>
div {
width: 100px;
height: 100px;
background: #ccc;
border: 1px solid #000;
}
</style>
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script>
</head>
<body>
<button>toggle the div</button>
<div></div>
<script>
$( "button" ).click(function() {
$( "div" ).toggle( "fold", 1000 );
});
</script>
</body>
</html>
```
- 介紹
- 索引
- Effects
- .addClass()
- Blind Effect
- Bounce Effect
- Clip Effect
- Color Animation
- Drop Effect
- Easings
- .effect()
- Explode Effect
- Fade Effect
- Fold Effect
- .hide()
- Highlight Effect
- Puff Effect
- Pulsate Effect
- .removeClass()
- Scale Effect
- Shake Effect
- .show()
- Size Effect
- Slide Effect
- .switchClass()
- .toggle()
- .toggleClass()
- Transfer Effect
- Effect Core
- Interactions
- Draggable Widget
- Droppable Widget
- Mouse Interaction
- Resizable Widget
- Resizable Widget
- Selectable Widget
- Sortable Widget
- Method Overrides
- .focus()
- .position()
- Methods
- .disableSelection()
- .enableSelection()
- .removeUniqueId()
- .scrollParent()
- .uniqueId()
- .zIndex()
- Selectors
- :data() Selector
- :focusable Selector
- :tabbable Selector
- Theming
- CSS 框架(CSS Framework)
- Icons
- Stacking Elements
- UI Core
- Utilities
- Widget Factory
- Widget Plugin Bridge
- Widgets
- Accordion Widget
- Autocomplete Widget
- Button Widget
- Datepicker Widget
- Dialog Widget
- Menu Widget
- Progressbar Widget
- Slider Widget
- Spinner Widget
- Tabs Widget
- Tooltip Widget
- upscayl使用教程