php - Android 从 mysql JSON 数据填充微调器

标签 php android mysql json

我有 2 个旋转器,一个用于省份,另一个用于城市。但它们相互依赖。如果我在省份微调器中选择豪登省,则第二个微调器必须显示约翰内斯堡、比勒陀利亚、百夫长,如果我在省份中选择 KZN,我希望第二个微调器显示彼得马里茨堡、德类、乌伦迪。

这是我的代码。我可以从我的 mysql 数据库填充 spinner,但我无法创建其他依赖项

第一个旋转器 JSON 数据:

   "Provinces": [
    {
        "provinceid": "1",
        "provincename": "A"
    },
    {
        "provinceid": "2",
        "provincename": "B"
    }
]}

第二个旋转器 JSON 数据:(它与我的 php 和 db 中的省份相关。

//获取列出城市的值 $provinceid= $_POST['provinceid'];)

{
"Cities": [
    {
        "cityid": "1",
        "cityname": "AA"
    },
    {
        "cityid": "2",
        "cityname": "BB"
    }
]}

这是我的java代码。

private ArrayList<String> province;
private ArrayList<String> city;
private JSONArray provinces;

String ilceid;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);     
   setContentView(R.layout.activity_welcome);

                ilce = new ArrayList<String>();

                //Initializing Spinner
                spinner = (Spinner) findViewById(R.id.spinner);
                spinner2 = (Spinner) findViewById(R.id.spinner2);


                //Adding an Item Selected Listener to our Spinner
                //As we have implemented the class Spinner.OnItemSelectedListener to this class iteself we are passing this to setOnItemSelectedListener
                spinner.setOnItemSelectedListener(WelcomeActivity.this);
                spinner2.setOnItemSelectedListener(WelcomeActivity.this);
                getData();

}


private void getData(){
    //Creating a string request
    StringRequest stringRequest = new StringRequest(SharedPrefManager.DATA_URL,
            new Response.Listener<String>() {
                @Override
                public void onResponse(String response) {
                    JSONObject j = null;
                    try {
                        //Parsing the fetched Json String to JSON Object
                        j = new JSONObject(response);

                        //Storing the Array of JSON String to our JSON Array
                        provinces= j.getJSONArray(SharedPrefManager.JSON_ARRAY);


                        getProvinces(provinces);
                    } catch (JSONException e) {
                        e.printStackTrace();
                    }
                }
            },
            new Response.ErrorListener() {
                @Override
                public void onErrorResponse(VolleyError error) {

                }
            });

    //Creating a request queue
    RequestQueue requestQueue = Volley.newRequestQueue(this);

    //Adding request to the queue
    requestQueue.add(stringRequest);
}
private void getProvinces(JSONArray j){
    //Traversing through all the items in the json array
    for(int i=0;i<j.length();i++){
        try {
            //Getting json object
            JSONObject json = j.getJSONObject(i);


            province.add(json.getString(SharedPrefManager.TAG_PROVINCENAME));
        } catch (JSONException e) {
            e.printStackTrace();
        }
    }

    //Setting adapter to show the items in the spinner
    spinner.setAdapter(new ArrayAdapter<String>(WelcomeActivity.this, android.R.layout.simple_spinner_dropdown_item, province));
}
private String getProvinceId(int position){
    String provid="";
    try {
        JSONObject json = provinces.getJSONObject(position);
        course = json.getString(SharedPrefManager.TAG_PROVINCEID);
    } catch (JSONException e) {
        e.printStackTrace();
    }
    return provid;
}


@Override
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
}

@Override
public void onNothingSelected(AdapterView<?> parent) {
}}

第一个旋转器在这种情况下有效。但是我如何根据第一个微调器填充 spinner2 ?

最佳答案

您甚至不需要从数据库获取该数据,它们对于所有用户都是相同的,并且无法更改,因此您可以将该数据放入应用程序中。但如果你真的需要它,那么你将把它分开,当用户选择第一个选项时,你需要将其发布到数据库,然后获取该选项的选项。我认为如果我了解您真正需要什么,就没有其他方法了。

关于php - Android 从 mysql JSON 数据填充微调器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47614103/

相关文章:

php - 如何将数据库结果放入 ScrollBox

android - 为移动应用程序选择数据库的最佳实践

android - 在 Android [Titanium] 的标题中隐藏默认的应用程序图标和应用程序名称

MySQL 触发器没有像它应该的那样执行

jquery - 我们可以将 mysql 与 node.js 一起使用吗

PHP:从php文件中获取PHP的变量、函数、常量

php - 带参数的 Paypal IPN 回调

php - 如何守护一个 php 脚本以与 upstart 一起运行

android - 设备关闭时发送短信

mysql - 查询中的棘手条件