原作者:http://www.open-open.com/lib/view/open1433385856119.html

1 背景

上周一年一度的Google IO全球开发者大会刚刚结束,Google在Android这块除过一些优化没有太大亮点。在Android Developer和Android Developer Blog上看了下相关介绍,Google升级了新的Support Library。所以在这里我们就来率先体验一把吧(这篇文章再草稿箱呆了三四天了。。。。终于有时间让她见天日了)。

先看一下Demo演示效果图,完全使用了Google IO 2015的Design Support Library的控件进行代码编写。如下:

下载Demo请点击:Design Support Library Demo

2 Design Support Library使用介绍

2-1 综述

支持Android 2.1以上设备。

Gradle build script dependency:

  1. compile 'com.android.support:design:22.2.0' //可修改版本号为自己匹配

Design Support Library包含8个控件,具体如下:

Widget Name Description
android.support.design.widget.TextInputLayout 强大带提示的MD风格的EditText
android.support.design.widget.FloatingActionButton MD风格的圆形按钮,来自于ImageView
android.support.design.widget.Snackbar 类似Toast,添加了简单的单个Action
android.support.design.widget.TabLayout 选项卡
android.support.design.widget.NavigationView DrawerLayout的SlideMenu
android.support.design.widget.CoordinatorLayout 超级FrameLayout
android.support.design.widget.AppBarLayout MD风格的滑动Layout
android.support.design.widget.CollapsingToolbarLayout 可折叠MD风格ToolbarLayout

下面详细说说这些控件的特性和使用注意项。

2-2 TextInputLayout控件

在MD中,使用TextInputLayout将EditText进行了封装,提示信息会变成一个显示在EditText之上的floating label,这样用户就始终知道他们现在输入的是什么,而且过度动画是平滑的。还可以在下方通过setError设置Error提示,使用比较简单,所以不做过多说明,详情见Demo源码。

本人布局:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:tools="http://schemas.android.com/tools"
  4. android:id="@+id/activity_main"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent"
  7.  
  8. tools:context="com.example.administrator.myapplication.MainActivity">
  9.  
  10. <android.support.design.widget.TextInputLayout
  11. android:layout_width="match_parent"
  12. android:id="@+id/til"
  13. android:layout_height="wrap_content"
  14. android:orientation="vertical"
  15. >
  16. <EditText
  17. android:hint="请输入"
  18. android:layout_width="match_parent"
  19. android:id="@+id/et1"
  20. android:layout_height="wrap_content" />
  21. <TextView
  22.  
  23. android:layout_width="match_parent"
  24. android:text="asd"
  25. android:layout_height="wrap_content" />
  26. </android.support.design.widget.TextInputLayout>
  27. </RelativeLayout>
  1. package com.example.administrator.myapplication;
  2.  
  3. import android.os.Bundle;
  4. import android.support.design.widget.TextInputLayout;
  5. import android.support.v7.app.AppCompatActivity;
  6. import android.text.Editable;
  7. import android.text.TextWatcher;
  8. import android.widget.EditText;
  9.  
  10. public class MainActivity extends AppCompatActivity {
  11.  
  12. private TextInputLayout til;
  13. private EditText et1;
  14.  
  15. @Override
  16. protected void onCreate(Bundle savedInstanceState) {
  17. super.onCreate(savedInstanceState);
  18. setContentView(R.layout.activity_main);
  19. til = (TextInputLayout) findViewById(R.id.til);
  20. et1 = (EditText) findViewById(R.id.et1);
  21.  
  22. EditText editText = til.getEditText();
  23. editText.addTextChangedListener(new TextWatcher() {
  24. @Override
  25. public void beforeTextChanged(CharSequence s, int start, int count, int after) {
  26.  
  27. }
  28.  
  29. @Override
  30. public void onTextChanged(CharSequence s, int start, int before, int count) {
  31. if (s.length()>5){
  32. til.setErrorEnabled(true);
  33. til.setError("长度不能大于5");
  34. }else {
  35. til.setErrorEnabled(false);
  36. }
  37. }
  38.  
  39. @Override
  40. public void afterTextChanged(Editable s) {
  41.  
  42. }
  43. });
  44.  
  45. }
  46. }

注意项:

TextInputLayout中最多嵌套1个EditText。

2-3 FloatingActionButton控件

一个负责显示界面基本操作的圆形按钮。Design library中的FloatingActionButton 实现了一个默认颜色为主题中colorAccent的悬浮操作按钮。除了一般大小的悬浮操作按钮,它还支持mini size(fabSize=”mini”)。FloatingActionButton继承自ImageView,你可以使用android:src或者 ImageView的任意方法,比如setImageDrawable()来设置FloatingActionButton里面的图标。

布局

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:tools="http://schemas.android.com/tools"
  4. android:id="@+id/activity_main"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent"
  7. tools:context="com.example.administrator.myapplication.MainActivity">
  8.  
  9. <android.support.design.widget.FloatingActionButton
  10. android:id="@+id/fab"
  11. android:layout_gravity="right|bottom"
  12. android:layout_width="wrap_content"
  13. android:layout_height="wrap_content" />
  14.  
  15. </android.support.design.widget.CoordinatorLayout>

  1. package com.example.administrator.myapplication;
  2.  
  3. import android.os.Bundle;
  4. import android.support.design.widget.FloatingActionButton;
  5. import android.support.v7.app.AppCompatActivity;
  6.  
  7. public class MainActivity extends AppCompatActivity {
  8.  
  9. private FloatingActionButton fab;
  10.  
  11. @Override
  12. protected void onCreate(Bundle savedInstanceState) {
  13. super.onCreate(savedInstanceState);
  14. setContentView(R.layout.activity_main);
  15. fab = (FloatingActionButton) findViewById(R.id.fab);
  16. fab.setImageDrawable(getResources().getDrawable(R.mipmap.ic_launcher));
  17. }
  18. }

特别注意项:

如果你 你用了SnackBar那么强烈建议根布局用coordinatorLayout不然弹出来的时候Floating会在snackBar下面不会顶起来

2-4 Snackbar控件

Snackbar为一个操作提供轻量级、快速的反馈。Snackbar显示在屏幕的底部(有MD动画效果浮现和消失),包含了文字信息与一个可选的操作按钮。在指定时间结束之后自动消失。另外,用户还可以在超时之前将它滑动删除。Snackbar被看作是比Toast更强大的快速反馈机制,你会发现他们的API非常相似。你应该注意到了make()方法中把一个View作为第一个参数(Snackbar试图找到一个合适的父亲以确保自己是被放置于底部)。

无特殊注意项,和Toast类似。

  1. package com.example.administrator.myapplication;
  2.  
  3. import android.os.Bundle;
  4. import android.support.design.widget.CoordinatorLayout;
  5. import android.support.design.widget.Snackbar;
  6. import android.support.v7.app.AppCompatActivity;
  7. import android.view.View;
  8.  
  9. public class MainActivity extends AppCompatActivity {
  10.  
  11. private CoordinatorLayout viewById;
  12.  
  13. @Override
  14. protected void onCreate(Bundle savedInstanceState) {
  15. super.onCreate(savedInstanceState);
  16. setContentView(R.layout.activity_main);
  17. viewById = ((CoordinatorLayout) findViewById(R.id.activity_main));
  18. /**
  19. * Snackbar.LENGTH_LONG 2秒播放的时间
  20. * Snackbar.LENGTH_SHORT 1.5 播放时间
  21. * Snackbar.LENGTH_INDEFINITE一直存在直到下个snakebar出现
  22. */
  23. Snackbar.LENGTH_LONG
  24. Snackbar snackbar = Snackbar.make(viewById, "你好啊", Snackbar.LENGTH_INDEFINITE);
  25. snackbar.setAction("确定", new View.OnClickListener() {
  26. @Override
  27. public void onClick(View v) {
  28. // Snackbar.make(viewById,"嘿嘿",Snackbar.LENGTH_SHORT).show();
  29. }
  30. });
  31. snackbar.show();
  32.  
  33. }
  34. }

2-5 TabLayout控件

通过选项卡的方式切换View并不是MD中才有的新概念,它们和顶层导航模式或者组织app中不同分组内容(比如,不同风格的音乐)是同一个概念。 Design library的TabLayout 既实现了固定的选项卡(View的宽度平均分配),也实现了可滚动的选项卡(View宽度不固定同时可以横向滚动)。如果你使用ViewPager在 tab之间横向切换,你可以直接从PagerAdapter的getPageTitle() 中创建选项卡,然后使用setupWithViewPager()将两者联系在一起。它可以使tab的选中事件能更新ViewPager,同时 ViewPager 
的页面改变能更新tab的选中状态。

更详细tabLayout 使用

http://www.jianshu.com/p/2b2bb6be83a8

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:tools="http://schemas.android.com/tools"
  4. xmlns:app="http://schemas.android.com/apk/res-auto"
  5. android:id="@+id/activity_main"
  6. android:layout_width="match_parent"
  7. android:layout_height="match_parent"
  8. android:orientation="vertical"
  9. tools:context="com.example.administrator.myapplication.MainActivity">
  10.  
  11. <android.support.design.widget.TabLayout
  12. android:layout_width="match_parent"
  13. android:id="@+id/tl"
  14. app:tabIndicatorHeight="3dp"
  15. app:tabIndicatorColor="#f00"
  16. app:tabSelectedTextColor="#ff0"
  17. android:background="@color/colorPrimaryDark"
  18. app:tabMode="fixed"
  19.  
  20. android:layout_height="wrap_content"></android.support.design.widget.TabLayout>
  21.  
  22. <android.support.v4.view.ViewPager
  23. android:id="@+id/vp"
  24. android:layout_width="match_parent"
  25. android:layout_height="200dp">
  26.  
  27. </android.support.v4.view.ViewPager>
  28.  
  29. </LinearLayout>

  1. package com.example.administrator.myapplication;
  2.  
  3. import android.os.Bundle;
  4. import android.support.design.widget.TabLayout;
  5. import android.support.v4.view.PagerAdapter;
  6. import android.support.v4.view.ViewPager;
  7. import android.support.v7.app.AppCompatActivity;
  8. import android.view.View;
  9. import android.view.ViewGroup;
  10. import android.widget.TextView;
  11.  
  12. public class MainActivity extends AppCompatActivity {
  13.  
  14. private TabLayout tabLayout;
  15. private ViewPager vp;
  16. TextView [] tvs = new TextView[10];
  17. String []titles = {"第一","第二","第三","第4","第5","第一","第二","第三","第4","第5"};
  18. @Override
  19. protected void onCreate(Bundle savedInstanceState) {
  20. super.onCreate(savedInstanceState);
  21. setContentView(R.layout.activity_main);
  22. tabLayout = (TabLayout) findViewById(R.id.tl);
  23. vp = (ViewPager) findViewById(R.id.vp);
  24. for (int i = 0; i < tvs.length; i++) {
  25. TextView tv = new TextView(this);
  26. tv.setWidth(200);
  27. tv.setHeight(500);
  28. tv.setText(i+"");
  29. tvs[i]=tv;
  30.  
  31. }
  32. Myadapter myadapter = new Myadapter();
  33. vp.setAdapter(myadapter);
  34. //如果绑定viewpager此方法不显示 只会显示vp的getPageTitle
  35. /* tabLayout.addTab(tabLayout.newTab().setText("Tab 4").setIcon(R.mipmap.ic_launcher));
  36.  
  37. tabLayout.addTab(tabLayout.newTab().setText("Tab 5"));
  38.  
  39. tabLayout.addTab(tabLayout.newTab().setText("Tab 6"));
  40.  
  41. tabLayout.addTab(tabLayout.newTab().setText("Tab 7"));*/
  42. tabLayout.setupWithViewPager(vp);
  43.  
  44. }
  45.  
  46. class Myadapter extends PagerAdapter{
  47.  
  48. @Override
  49. public int getCount() {
  50. return tvs.length;
  51. }
  52.  
  53. @Override
  54. public Object instantiateItem(ViewGroup container, int position) {
  55.  
  56. container.addView(tvs[position]);
  57. return tvs[position];
  58. }
  59.  
  60. @Override
  61. public void destroyItem(ViewGroup container, int position, Object object) {
  62. // super.destroyItem(container, position, object);
  63. container.removeView((View) object);
  64. }
  65.  
  66. @Override
  67. public boolean isViewFromObject(View view, Object object) {
  68. return view==object;
  69. }
  70.  
  71. @Override
  72. public CharSequence getPageTitle(int position) {
  73. return titles[position];
  74. }
  75.  
  76. }
  77. }

注意项:

如果你使用ViewPager在tab之间横向切换,切记可以直接从PagerAdapter的getPageTitle() 中创建选项卡,然后使用setupWithViewPager()将两者联系在一起。

2-6 NavigationView控件

抽屉导航是app识别度与内部导航的关键,保持这里设计上的一致性对app的可用性至关重要,尤其是对于第一次使用的用户。 NavigationView 通过提供抽屉导航所需的框架让实现更简单,同时它还能够直接通过菜单资源文件直接生成导航元素。把NavigationView作为 DrawerLayout的内容视图来使用。NavigationView处理好了和状态栏的关系,可以确保NavigationView在API21+ 设备上正确的和状态栏交互。

MENU文件

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <menu xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:app="http://schemas.android.com/apk/res-auto"
  4. >
  5. <group>
  6. <item
  7. android:id="@+id/item1"
  8. app:showAsAction="always"
  9. android:title="item1"
  10. android:icon="@mipmap/ic_launcher"
  11. />
  12. <item
  13. app:showAsAction="always"
  14. android:id="@+id/item2"
  15. android:title="item2"
  16. android:icon="@mipmap/ic_launcher"
  17. />
  18. </group>
  19. <item
  20. app:showAsAction="never"
  21. android:id="@+id/item3"
  22. android:title="item3"
  23. android:icon="@mipmap/ic_launcher"
  24. />
  25. </menu>

头布局

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout
  3. android:background="#f0f"
  4. xmlns:android="http://schemas.android.com/apk/res/android"
  5. android:layout_width="match_parent"
  6. android:layout_height="200dp"
  7. android:orientation="vertical">
  8.  
  9. <TextView
  10. android:id="@+id/tt"
  11. android:layout_width="wrap_content"
  12. android:layout_height="wrap_content"
  13. android:text="头布局" />
  14. </LinearLayout>

布局:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:tools="http://schemas.android.com/tools"
  4. xmlns:app="http://schemas.android.com/apk/res-auto"
  5. android:id="@+id/activity_main"
  6. android:layout_width="match_parent"
  7. android:layout_height="match_parent"
  8. android:orientation="vertical"
  9.  
  10. tools:context="com.example.administrator.myapplication.MainActivity">
  11.  
  12. <FrameLayout
  13.  
  14. android:layout_width="match_parent"
  15. android:background="#ff0"
  16. android:layout_height="match_parent"/>
  17. <!--app:headerLayout="@layout/head"-->
  18. <android.support.design.widget.NavigationView
  19. android:layout_width="300dp"
  20. app:menu="@menu/my_menu1"
  21.  
  22. android:id="@+id/navigation"
  23. android:layout_gravity="left"
  24. android:layout_height="match_parent"/>
  25.  
  26. </android.support.v4.widget.DrawerLayout>

  1. package com.example.administrator.myapplication;
  2.  
  3. import android.os.Bundle;
  4. import android.support.annotation.NonNull;
  5. import android.support.design.widget.NavigationView;
  6. import android.support.design.widget.Snackbar;
  7. import android.support.v7.app.AppCompatActivity;
  8. import android.view.MenuItem;
  9. import android.view.View;
  10. import android.widget.TextView;
  11.  
  12. public class MainActivity extends AppCompatActivity {
  13.  
  14. private NavigationView navigationView;
  15. private TextView textView;
  16.  
  17. @Override
  18. protected void onCreate(Bundle savedInstanceState) {
  19. super.onCreate(savedInstanceState);
  20. setContentView(R.layout.activity_main);
  21. navigationView = (NavigationView) findViewById(R.id.navigation);
  22. navigationView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() {
  23. @Override
  24. public boolean onNavigationItemSelected(@NonNull MenuItem item) {
  25.  
  26. Snackbar.make(navigationView, item.getTitle(),Snackbar.LENGTH_SHORT).show();
  27.  
  28. return false;
  29. }
  30. });
  31.  
  32. //最后一个参数说明 要不要直接添加到父布局中
  33. //第二个参数设置你父布局 是谁 ,如果是null 那么添加到addHeaderView 中时高度不生效等
  34. View inflate = getLayoutInflater().inflate(R.layout.head, navigationView, false);
  35. navigationView.addHeaderView(inflate);
  36.  
  37. }
  38.  
  39. }

注意项:

你可以通过设置一个OnNavigationItemSelectedListener,使用其 setNavigationItemSelectedListener()来获得元素被选中的回调事件。它为你提供被点击的菜单元素,让你可以处理选择事件、改变复选框状态、加载新内容、关闭导航菜单,以及其他任何你想做的操作。你会注意到NavigationView的两个新自定义属性如下:

new attr description
app:headerLayout 控制头部的布局
app:menu 导航菜单的资源文件(也可以在运行时配置)

2-7 CoordinatorLayout控件

手势,及滚动布局,MD的手势有很多组成部分,包括touch ripples和meaningful transitions。Design library引入了CoordinatorLayout,一个从另一层面去控制子view之间触摸事件的布局,Design library中的很多控件都利用了它。一个很好的例子就是当你将FloatingActionButton作为一个子View添加进 CoordinatorLayout并且将CoordinatorLayout传递给 Snackbar.make(),在3.0及其以上的设备上,Snackbar不会显示在悬浮按钮的上面,而是FloatingActionButton 利用CoordinatorLayout提供的回调方法,在Snackbar以动画效果进入的时候自动向上移动让出位置,并且在Snackbar动画地消失的时候回到原来的位置,不需要额外的代码。

CoordinatorLayout的另一个用例是ActionBar与滚动技巧。你可能已经在自己的布局中使用了Toolbar ,它允许你更加自由的自定义其外观与布局的其余部分融为一体。Design library把这种设计带到了更高的水平,使用AppBarLayout可以让你的Toolbar与其他View(比如TabLayout的选项卡)能响应被标记了ScrollingViewBehavior的View的滚动事件。

注意项:

当用户滚动RecyclerView,AppBarLayout可以这样响应滚动事件:

根据子view的滚动标志(scroll flag)来控制它们如何进入(滚入屏幕)与退出(滚出屏幕)。

Flag包括:

  • scroll:所有想滚动出屏幕的View都需要设置这个flag,没有设置这个flag的View将被固定在屏幕顶部。
  • enterAlways:这个flag让任意向下的滚动都会导致该View变为可见,启用快速“返回模式”。
  • enterAlwaysCollapsed:当你的视图已经设置minHeight属性又使用此标志时,你的视图只能已最小高度进入,只有当滚动视图到达顶部时才扩大到完整高度。
  • exitUntilCollapsed:this flag causes the view to scroll off until it is ‘collapsed’ (its minHeight) before exiting。

特别注意:所有使用scroll flag的View都必须定义在没有使用scroll flag的View前面,这样才能确保所有的View从顶部退出,留下固定的元素。

PS一句:CoordinatorLayout还提供了layout_anchor和layout_anchorGravity属性一起配合使用,可以用于放置floating view,比如FloatingActionButton与其他View的相对位置。相见Demo中演示。

2-8 AppBarLayout控件

这个没啥解释的,就是一个ViewGroup,配合ToolBar与CollapsingToolbarLayout等使用。就是一个纯容器类。

无特殊注意项。

2-9 CollapsingToolbarLayout控件

可伸缩折叠的Toolbar (Collapsing Toolbar),直接添加Toolbar到AppBarLayout可以让你使用enterAlwaysCollapsed和 exitUntilCollapsedscroll标志,但是无法控制不同元素如何响应collapsing的细节。这里使用了 CollapsingToolbarLayout的app:layout_collapseMode=”pin”来确保Toolbar在view折叠的时候仍然被固定在屏幕的顶部。还可以做到更好的效果,当你让CollapsingToolbarLayout和Toolbar在一起使用的时候,title 会在展开的时候自动变得大些,而在折叠的时候让字体过渡到默认值。必须注意,在这种情况下你必须在CollapsingToolbarLayout上调用 setTitle(),而不是在Toolbar上。除了固定住View,你还可以使用 app:layout_collapseMode=”parallax”(以及使用 app:layout_collapseParallaxMultiplier=”0.7”来设置视差因子)来实现视差滚动效果(比如 CollapsingToolbarLayout里面的一个ImageView),这中情况和CollapsingToolbarLayout的 app:contentScrim=”?attr/colorPrimary”属性一起配合更完美。

有一件事情必须注意,那就是CoordinatorLayout并不知道FloatingActionButton或者AppBarLayout的内部工作原理,它只是以Coordinator.Behavior的形式提供了额外的API,该API可以使子View更好的控制触摸事件与手势以及声明它们之间的依赖,并通过onDependentViewChanged()接收回调。

可以使用CoordinatorLayout.DefaultBehavior(你的View.Behavior.class)注解或者在布局中使用app:layout_behavior=”com.example.app.你的View$Behavior”属性来定义view的默认行为。 framework让任意View和CoordinatorLayout结合在一起成为了可能。

注意项:

注意项上面描述部分已经声明,不需要额外说明。

3 总结

到此2015 Google IO的新suppory包控件完全介绍完毕。详细细节可以翻墙阅读AD的developer->tools->support library。至此只能期待Android M尽快发布呀。

PS:已经用上了Android Studio 1.3预览版,只是M得编译会出错,有BUG,别的暂时没发现啥区别,还有一点,比1.2貌似快了一点,哈哈,是我心里作用么?

下载Demo请点击:Design Support Library Demo

【工匠若水 http://blog.csdn.net/yanbober 转载烦请注明出处,尊重分享成果】

安卓高级3 Android应用Design Support Library完全使用实例的更多相关文章

  1. Android应用Design Support Library完全使用实例

    阅读目录 2-1 综述 2-2 TextInputLayout控件 2-3 FloatingActionButton控件 2-4 Snackbar控件 2-5 TabLayout控件 2-6 Navi ...

  2. Android material design support library -- CollapsingToolbarLayout简介

    本文是codetrick上material design support library教程的第三篇,主要讲的是CollapsingToolbarLayout的概念和应用方法. 原文链接:Materi ...

  3. Android Meterial Design Support Library

    extends:http://inthecheesefactory.com/blog/android-design-support-library-codelab At the moment I be ...

  4. 如何使用android design support library

    Android应用Design Support Library完全使用实例 - OPEN 开发经验库http://www.open-open.com/lib/view/open143338585611 ...

  5. 【转】Android的材料设计兼容库(Design Support Library)

    转自:http://www.jcodecraeer.com/a/anzhuokaifa/developer/2015/0531/2958.html?mType=Group Android的材料设计兼容 ...

  6. Android Design Support Library——Navigation View

    前沿 Android 从5.0开始引入了Material design元素的设计,这种新的设计语言让整个安卓的用户体验焕然一新,google在Android Design Support Librar ...

  7. Android Design Support Library使用详解

    Android Design Support Library使用详解 Google在2015的IO大会上,给我们带来了更加详细的Material Design设计规范,同时,也给我们带来了全新的And ...

  8. Android开发学习之路-Android Design Support Library使用(CoordinatorLayout的使用)

    效果图: 上面的这个图有两个效果是,一个是顶部的图片,在上滑之后会隐藏起来并且显示出一个ToolBar(ToolBar类似于ActionBar,但是只有ToolBar是兼容Material Desig ...

  9. 【转】【翻】Android Design Support Library 的 代码实验——几行代码,让你的 APP 变得花俏

    转自:http://mrfufufu.github.io/android/2015/07/01/Codelab_Android_Design_Support_Library.html [翻]Andro ...

随机推荐

  1. JSON定义

    如果我们要在不同的编程语言之间传递对象,就必须把对象序列化为标准格式,比如xml,但更好的方法是序列化为JSON,因为JSON表示出来就是一个字符串,可以被所有语言读取,也可以方便地存储到磁盘或者通过 ...

  2. 关于CORS跨域问题的理解

    起因 因为这段时间一个项目前后端分别部署在不同服务器的需要,抽空学习了一下CORS问题,不足之处,欢迎指教. 什么是CORS CORS是一个w3c标准,全称是"跨域资源共享"(Cr ...

  3. MyBatis基础学习笔记--摘录

    1.MyBatis是什么? MyBatis源自于IBatis,是一个持久层框架,封装了jdbc操作数据库的过程,使得开发者只用关心sql语句,无需关心驱动加载.连接,创建statement,手动设置参 ...

  4. [HNOI 2004]敲砖块

    Description 在一个凹槽中放置了 n 层砖块.最上面的一层有n 块砖,从上到下每层依次减少一块砖.每块砖都有一个分值,敲掉这块砖就能得到相应的分值,如下图所示. 14 15 4 3 23 3 ...

  5. 【LSGDOJ 1850】滑雪课程

    题目描述 贝西去科罗拉多州去滑雪,不过还她不太会玩,只是个能力为 1 的渣渣.贝西从 0 时刻进入滑雪场,一到 T 时刻就必须离开.滑雪场里有 N 条斜坡,第 i 条斜坡滑行一次需要 D i 分钟,要 ...

  6. 【USACO17JAN】Promotion Counting晋升者计数 线段树+离散化

    题目描述 The cows have once again tried to form a startup company, failing to remember from past experie ...

  7. poj1681 高斯消元

    Painter's Problem Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 5352   Accepted: 2588 ...

  8. [bzoj4893]项链分赃

    来自FallDream的博客,未经允许,请勿转载,谢谢. 有一串长度为n(n<=10^5)的项链,上面有红绿蓝三种颜色的珠子,每种颜色的珠子数目都是偶数,现在要你把它切几刀分成若干段,把其中一些 ...

  9. jqGrid移动滑块时冻结首列和第二列例子

    js代码如以下代码:在initAllGrid函数colModel1加入属性设置:frozen:true:然后在_initGrid('task_con_grid_div',colModel1)函数里面加 ...

  10. 数据库学习番外篇 神奇的Redis

    数据库学习番外篇 神奇的Redis 由于最近呢小猿我找到了自己的女神,所以整个学习计划都被打乱了,本来想着一天看一张<SQLServer宝典>的.没成想,我竟然脱离了单身狗的队伍. 最近准 ...