如何在React Native中创建一个包含其他数组数据的新数组?

时间:2018-09-10 07:24:09

标签: arrays loops react-native

如何从另一个数组创建新数组

我的数组是data1

this.state = {
    data1: [
        {'x':'%20', 'y':11, 'z':'sunday'},
        {'x':'%30', 'y':21, 'z':'monday'},
        {'x':'%40', 'y':31, 'z':'tuesday'}          
    ],
    data2: [],
}

我想创建data2,看起来像这样

data2: [
    {'x':'%20-(11)-sunday'},
    {'x':'%30-(21)-monday'},
    {'x':'%40-(31)-tuesday'}
]

3 个答案:

答案 0 :(得分:1)

看看array.map

const data2 = data1.map(value => ({ x: `${value.x}-(${value.y})-${value.z}` }))

答案 1 :(得分:0)

您可以使用以下函数将data1数组转换为data2数组:

createCustomArray() {
   this.state.data1.forEach(function (item) {
      this.state.data2.push({'x': item.x+'-('+item.y+')-'+item.z});
   });
}

答案 2 :(得分:0)

public class MainActivity extends AppCompatActivity implements OnMapReadyCallback {

    private GoogleMap mMap;
    private FusedLocationProviderClient mFusedLocationClient;

    private static final int LOCATION_PERMISSION_REQUEST_CODE = 537;

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

        init();
    }

    private void init() {
    //    Initializing Objects...
        mFusedLocationClient = LocationServices.getFusedLocationProviderClient(this);
        SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
                .findFragmentById(R.id.map);
        if (mapFragment != null) {
            mapFragment.getMapAsync(this);
        }
    }

    @Override
    public void onMapReady(GoogleMap googleMap) {
    // onMapReady check Permission and load map...
    // If Permission not granted ask for permission...
        if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION)
                == PackageManager.PERMISSION_GRANTED) {
            mMap = googleMap;
            MoveCameraToCurrentPosition();
        } else {
            AskUserPermission();
        }
    }


    public void AskUserPermission() {
        //   Show Explanation and show permission dialog...
        //   Permission is not granted
        //   Show Explanation...

        //   shouldShowRequestPermissionRationale returns true if permission has previously
        //   denied by user..

        if (ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.ACCESS_FINE_LOCATION)) {
            // Show an explanation to the user *asynchronously* -- don't block
            // this thread waiting for the user's response! After the user
            // sees the explanation, try again to request the permission.
            final AlertDialog.Builder builder = new AlertDialog.Builder(this);
            builder.setTitle("Why we need Location Permission?");
            builder.setMessage("we want to forecast the weather alert like storms, Flood," +
                    "Hurricanes, etc. to you before hand based on your farm location, so that " +
                    "we can save your crops :).");
            builder.setNeutralButton("Got it.", new DialogInterface.OnClickListener() {
                @Override
                public void onClick(DialogInterface dialogInterface, int i) {
                    dialogInterface.dismiss();
                    RequestLocationPermission();
                }
            });
            builder.show();
            RequestLocationPermission();
        } else {
            //  No Explanation Needed Request Permission...
            RequestLocationPermission();
        }
    }

    // Show Alert Dialog for permission...
    private void RequestLocationPermission() {
        // No explanation needed; request the permission
        ActivityCompat.requestPermissions(this, new String[]{Manifest.permission
                .ACCESS_COARSE_LOCATION,Manifest.permission.ACCESS_FINE_LOCATION},
                LOCATION_PERMISSION_REQUEST_CODE);
    }

    // Fetch Request Permission result and update current location...
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        switch (requestCode) {
            case LOCATION_PERMISSION_REQUEST_CODE:
                if (grantResults.length > 0
                        && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                    // This code is not executing even after giving permission..
                    MoveCameraToCurrentPosition();
                }
                break;
        }

    }
    // Move camera to current location...
    private void MoveCameraToCurrentPosition(){
        if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION)
                == PackageManager.PERMISSION_GRANTED) {
            mFusedLocationClient.getLastLocation()
                    .addOnSuccessListener(this, new OnSuccessListener<Location>() {
                        @Override
                        public void onSuccess(Location location) {
                            // Got last known location. In some rare situations this can be null.
                            if (location != null) {
                                // Add a marker in Sydney, Australia, and move the camera.
                                LatLng sydney = new LatLng(location.getLatitude(), location.getLongitude());
                                mMap.addMarker(new MarkerOptions().position(sydney).icon(BitmapDescriptorFactory.fromResource(R.drawable.barley)).title("Your Location"));
                                CameraPosition cameraPosition = new CameraPosition(sydney, 10, 0, 0);
                                CameraUpdate cameraUpdate = CameraUpdateFactory.newCameraPosition(cameraPosition);
                                mMap.animateCamera(cameraUpdate);
                            }
                        }
                    });
        } else {
            AskUserPermission();
        }
    }
}