Android xUtils框架最全使用详解

xUtils3简介

xUtils 包含了orm, http(s), image, view注解, 但依然很轻量级(251K), 并且特性强大, 方便扩展.
官网:https://github.com/wyouflf/xUtils3

xUtils使用方法

使用前准备

第一步:引入

implementation 'org.xutils:xutils:3.8.5'

第二步:添加权限

<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

AndroidManifest.xml文件application 节点里添加

android:requestLegacyExternalStorage="true"
android:usesCleartextTraffic="true"

第三步:MainActivity中添加

x.Ext.init(getApplication());
x.Ext.setDebug(BuildConfig.DEBUG);// 是否输出debug日志, 开启debug会影响性能.
x.view().inject(this);//没有用到view注解可以先不用

功能1:访问网络

不带参数的网络请求

不带缓存

RequestParams params = new RequestParams("http://baidu.com");
x.http().get(params, new Callback.CommonCallback<String>() {
    @Override
    public void onSuccess(String result) {
        
    }

    @Override
    public void onError(Throwable ex, boolean isOnCallback) {

    }

    @Override
    public void onCancelled(CancelledException cex) {

    }

    @Override
    public void onFinished() {

    }
});

带缓存

RequestParams params = new RequestParams("http://baidu.com");
x.http().get(params, new Callback.CacheCallback<String>() {
    @Override
    public boolean onCache(String result) {
        return false;
    }

    @Override
    public void onSuccess(String result) {
        Log.i("MainActivity", result);
  
    }

    @Override
    public void onError(Throwable ex, boolean isOnCallback) {
        Log.i("MainActivity", ex.getMessage());
    }

    @Override
    public void onCancelled(CancelledException cex) {

    }

    @Override
    public void onFinished() {

    }
});

带参数的请求

RequestParams params = new RequestParams("https://www.baidu.com/s");
    // params.setSslSocketFactory(...); // 如果需要自定义SSL
params.addQueryStringParameter("wd", "xUtils");

功能2:加载网络图片

ImageOptions imageOptions;
imageOptions = new ImageOptions.Builder()
                .setSize(DensityUtil.dip2px(120), DensityUtil.dip2px(120))
                .setRadius(DensityUtil.dip2px(5))
                // 如果ImageView的大小不是定义为wrap_content, 不要crop.
                .setCrop(true) // 很多时候设置了合适的scaleType也不需要它.
                // 加载中或错误图片的ScaleType
                //.setPlaceholderScaleType(ImageView.ScaleType.MATRIX)
                .setImageScaleType(ImageView.ScaleType.CENTER_CROP)
                .setLoadingDrawableId(R.mipmap.ic_launcher)
                .setFailureDrawableId(R.mipmap.ic_launcher)
                .build();
// 加载网络图片
x.image().bind(imageView, url, imageOptions);

// 加载本地assets目录的图片
x.image().bind(imageView, "assets://test.gif", imageOptions);

// resources file
x.image().bind(imageView, "res://" + R.minimap.test, imageOptions);

// local file
x.image().bind(imageView, new File("/sdcard/test.gif").toURI().toString(), imageOptions);
x.image().bind(imageView, "/sdcard/test.gif", imageOptions);
x.image().bind(imageView, "file:///sdcard/test.gif", imageOptions);
x.image().bind(imageView, "file:/sdcard/test.gif", imageOptions);

x.image().bind(imageView, url, imageOptions, new Callback.CommonCallback<Drawable>() {...});
x.image().loadDrawable(url, imageOptions, new Callback.CommonCallback<Drawable>() {...});
// 用来获取缓存文件
x.image().loadFile(url, imageOptions, new Callback.CommonCallback<File>() {...});

功能3:框架注解

布局文件注解

//替代onCreate方法中的    setContentView(R.layout.activity_main);
@ContentView(R.layout.activity_main)
public class MainActivity extends AppCompatActivity {
}

控件注解

@ViewInject(R.id.textView)
private TextView mTextView;

点击事件注解

单个点击事件

/**
 * 1. 方法必须私有限定,
 * 2. 方法参数形式必须和type对应的Listener接口一致.
 * 3. 注解参数value支持数组: value={id1, id2, id3}
 * 4. 其它参数说明见{@link org.xutils.event.annotation.Event}类的说明.
 **/
@Event(value = R.id.btn_test1,
        type = View.OnClickListener.class/*可选参数, 默认是View.OnClickListener.class*/)
private void onTest1Click(View view) {
	...
}

多个点击事件

@Event(value = {R.id.button,R.id.button2},
        type = View.OnClickListener.class/*可选参数, 默认是View.OnClickListener.class*/)
private void onTest1Click(View view) {
 switch (view.getId()){
     case R.id.button:
            Log.i("MainActivity", "button1 click");
        break;
        case R.id.button2:
            Log.i("MainActivity", "button2 click");
            break;
    }
}

功能4:数据库映射

下面以单表为例演示xUtils框架怎么对数据库进行增删改查操作
首先添加一个实体类,在实体类上加一个注解

package com.hnu.sqlite.db;

import org.xutils.db.annotation.Column;
import org.xutils.db.annotation.Table;

@Table(name = "user")
public class User {
    @Column(name = "id", isId = true)
    private int id;
    @Column(name = "username")
    private String username;

    @Column(name = "password")
    private String password;

    @Column(name = "age")
    private int age;


    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                ", age=" + age +
                '}';
    }
}

在对数据库操作前,先创建DaoConfig 对象

    DbManager.DaoConfig daoConfig = new DbManager.DaoConfig()
            .setDbName("test.db")
            // 不设置dbDir时, 默认存储在app的私有目录.
	// .setDbDir(new File("/sdcard")) // "sdcard"的写法并非最佳实践, 这里为了简单, 先这样写了.
            .setDbVersion(2)
            .setDbOpenListener(new DbManager.DbOpenListener() {
                @Override
                public void onDbOpened(DbManager db) {
                    // 开启WAL, 对写入加速提升巨大
                    db.getDatabase().enableWriteAheadLogging();
                }
            })
            .setDbUpgradeListener(new DbManager.DbUpgradeListener() {
                @Override
                public void onUpgrade(DbManager db, int oldVersion, int newVersion) {
                    // TODO: ...
                    // db.addColumn(...);
                    // db.dropTable(...);
                    // ...
                    // or
                    // db.dropDb();
                }
            });

增加数据

 DbManager db = null;
 try {
     db = x.getDb(daoConfig);
     User user = new User();
     user.setUsername("test"+System.currentTimeMillis());
     user.setPassword("passwd");
     user.setAge(30);
     db.save(user);
 } catch (DbException e) {
     e.printStackTrace();
     return;
 }

删除数据

根据id 删除

DbManager db = null;
try {
    db = x.getDb(daoConfig);
    User user = new User();
    user.setId(2);
    db.delete(user);
} catch (DbException e) {
    e.printStackTrace();
    return;
}

根据条件删除

DbManager db = null;
try {  
    db = x.getDb(daoConfig);
    db.delete(User.class,
            WhereBuilder.b("username", "=", "test"));

} catch (DbException e) {
    e.printStackTrace();
    return;
}

修改数据

根据id修改

try { 
     DbManager db = null;
     db = x.getDb(daoConfig);
     User user = new User();
     user.setId(1);
     user.setUsername("new user");
     user.setPassword("new passwd");
     user.setAge(30);
     db.saveOrUpdate(user);
    // db.update(user);或者用这个方法修改
 } catch (DbException e) {
     e.printStackTrace();
     return;
 }

根据条件修改

try {  
	DbManager db = null;
	db = x.getDb(daoConfig);
	db.update(User.class, WhereBuilder.b("username", "=", "test"),
// WhereBuilder.b("id", "=", 1).and("isAdmin", "=", true).,
   new KeyValue("username", "test_name"), new KeyValue("password", "new pss"));
} catch (DbException e) {
	e.printStackTrace();
	return;
}

查询数据

DbManager db = null;
try {// 删除1
    db = x.getDb(daoConfig);
    List<User> users = new ArrayList<>();
    users= db.selector(User.class).orderBy("id", true).limit(1000).where("username","=","test").findAll();
// users= db.selector(User.class).orderBy("id", true).limit(1000).findAll();
// users= db.selector(User.class).findAll();
    for (User user : users){
        Log.i("testdb","test" + user);
    }

} catch (DbException e) {
    e.printStackTrace();
    return;
}
### 回答1: JS报uncaught syntaxerror: unexpected token <错误通常是因为在HTML页面中引入JS脚本的链接出现了问题。这个错误提示显示出了JS脚本引入的标签遭遇了一个不期望的"<"符号。 解决这个问题的方法是检查HTML页面中引用的JS脚本链接是否正确且完整。可以使用浏览器开发者工具找到报错的具体行号,并检查该行的链接是否正确。如果链接正确,可以尝试将JS代码复制到一个单独的JS文件中,然后再通过链接方式引用。如果仍然存在错误,可能是JS代码本身的问题,需要检查JS代码语法和逻辑是否正确。如果仍然无法解决问题,建议寻求更专业的技术支持或寻找更多相关教程和资料进行学习。 ### 回答2: 在使用JavaScript开发网站时,我们常常会遇到“Uncaught SyntaxError: Unexpected token <”这个错误。这个错误通常出现在我们的JavaScript代码中出现了“<”符号。这个符号在HTML代码中被广泛使用来表示标签的开头,但在JavaScript代码中,这个符号是一个特殊的字符,它表示字符串或表达式的小于(比较)运算符。因此,当我们在JavaScript代码中使用了“<”符号时,浏览器会认为这是一个意外的符号,从而引发了这个错误。 解决这个错误的方法有以下几种: 1. 检查JavaScript代码是否正确:首先,我们应该检查我们的JavaScript代码是否有任何语法错误或拼写错误。这通常可以通过使用浏览器的控制台来完成,控制台会显示JavaScript代码中的错误信息和行号。 2. 使用转义字符:如果我们必须在JavaScript代码中使用“<”符号,我们可以使用转义字符“\”来转义它。例如,我们可以使用“<”符号代替“\<”符号。 3. 将JavaScript代码放在正确的位置:有时,当我们将JavaScript代码放在错误的位置时,例如在HTML标签中间或在<script>标签之外,浏览器会将其解释为HTML代码,从而引发这个错误。因此,我们应该确保我们的JavaScript代码放在正确的位置,例如在<script>标签内或外部的JavaScript文件中。 4. 检查文件路径:在引用外部JavaScript文件时,我们应该确保文件路径是正确的。如果文件路径不正确,浏览器将无法加载JavaScript文件,从而导致这个错误。 5. 确保服务器已正确配置:如果我们的网站使用了服务器端脚本语言(例如PHP或ASP),我们应该确保服务器已正确配置,以便正确解释JavaScript代码。否则,浏览器将尝试在客户端解释服务器端的JavaScript代码,并引发这个错误。 总之,我们可以通过检查代码的语法及结构、使用转义字符、放置代码的位置和检查文件路径以及确保服务器已正确配置等方法来解决JavaScript中的“Uncaught SyntaxError: Unexpected token <”错误。 ### 回答3: JS在页面中报错时,返回的错误信息通常都很晦涩难懂,容易让人不知所措。uncaught syntaxerror: unexpected token <错误通常表示代码语法错误,通常是由于代码中缺少某个符号或引号、拼写错误等原因导致的。 首先,检查代码中是否有缺省的分号、括号、引号等未闭合。这些都是常见的语法错误,检查并及时修复可以大大缩短解决问题的时间。 其次,如果确定代码本身没有问题,则需要检查引入的外部文件,例如CSS、JS等文件。如果其中有文件错误,那么可能会导致JS也无法正常执行,所以要对所有文件进行检查。 另外,如果代码中使用了特殊字符、HTML标签等,也可能会引发这种错误。此时可以将这些内容用escape()函数进行转义处理,避免出现这种错误。 最后,可以使用开发者工具中的console.log()对代码进行逐行调试,定位出错误出现的位置。这种方法比较耗时,但可以有效地解决问题。 总之,解决uncaught syntaxerror: unexpected token <错误需要耐心,仔细地检查代码,尝试各种可能的解决方法。同时,建议平时写代码时注意细节,避免出现常见的语法错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Teacher.Hu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值