let arr = $ref<UE.TArray<string>>(); 添加数据
时间: 2024-06-02 11:06:38 浏览: 18
这是一行使用了蓝图节点引用的代码,它实际上是在使用虚幻引擎中的蓝图功能。这行代码的意思是创建了一个字符串类型的动态数组,名字为arr,并且它是一个UE.TArray类型的引用变量。如果想向这个动态数组添加数据,可以使用UE.TArray提供的Add()方法,比如:
```
arr.Add("hello");
arr.Add("world");
```
这样就向arr中添加了两个字符串元素,分别为"hello"和"world"。
相关问题
帮我把下边这块代码转成Java代码: private function query_arrtoxml($arr,$withRoot=true){ $xml =$withRoot?'<?xml version="1.0" encoding="utf-16" ?>':''; foreach ($arr as $key=>$val){ if(is_array($val)){ $xml.="<".$key.">".$this->query_arrtoxml($val,false)."</".$key.">"; }else{ $xml.="<".$key.">".$val."</".$key.">"; } } if($withRoot){ $xml.=""; } return $xml; }
以下是Java代码:
```
private String query_arrtoxml(Map<String, Object> arr, boolean withRoot) {
String xml = withRoot ? "<?xml version=\"1.0\" encoding=\"utf-16\" ?>" : "";
for (String key : arr.keySet()) {
Object val = arr.get(key);
if (val instanceof Map) {
xml += "<" + key + ">" + query_arrtoxml((Map<String, Object>) val, false) + "</" + key + ">";
} else {
xml += "<" + key + ">" + val + "</" + key + ">";
}
}
if (withRoot) {
xml += "";
}
return xml;
}
```
需要注意的是,Java中的Map对象需要用泛型来指定键值对的类型,所以我们将$arr改为了Map<String, Object>。此外,Java中的if语句需要用boolean类型来判断条件,所以我们将$is_withhead改为了withRoot,并将其类型改为了boolean。最后,Java中的字符串拼接需要使用+运算符,而不能像PHP中直接使用.运算符。
下列代码有什么错误:$sql = "select * from products"; $datarow = mysqli_num_rows($sql); $res= mysqli_query($conn,$sql); if($res){ echo'成功!'; echo'<hr/>'; for($i=0;$i<$datarow;$i++){ $sql_arr = mysql_fetch_assoc($sql); $id=$sql_arr['id']; $productname=$sql_arr['productname']; $category=$sql_arr['category']; $brand=$sql_arr['brand']; $image=$sql_arr['image']; $description=$sql_arr['description']; $price=$sql_arr['price']; echo "<tr><td>$id</td><td>$productname</td><td>$category</td><td>$brand</td><td>$image</td><td>$description</td><td>$price</td></tr>"; } }else{ echo'失败!'; }
这段代码有以下错误:
1. 没有连接到数据库。
2. `$datarow` 没有正确赋值,导致后面的循环无法正确执行,因为 `$datarow` 的值为字符串,而不是结果集的行数。
3. 在循环中使用了 `mysql_fetch_assoc()`,而不是 `mysqli_fetch_assoc()`,这会导致语法错误。
4. 在循环中没有对结果集进行遍历,导致无法获取到每一行的数据。
以下是修正后的代码:
```
// 连接到数据库
$conn = mysqli_connect("localhost", "username", "password", "database");
$sql = "select * from products";
$res = mysqli_query($conn, $sql);
$datarow = mysqli_num_rows($res);
if ($res) {
echo '成功!';
echo '<hr/>';
while ($sql_arr = mysqli_fetch_assoc($res)) {
$id = $sql_arr['id'];
$productname = $sql_arr['productname'];
$category = $sql_arr['category'];
$brand = $sql_arr['brand'];
$image = $sql_arr['image'];
$description = $sql_arr['description'];
$price = $sql_arr['price'];
echo "<tr><td>$id</td><td>$productname</td><td>$category</td><td>$brand</td><td>$image</td><td>$description</td><td>$price</td></tr>";
}
} else {
echo '失败!';
}
```
注意,这里使用了 `mysqli_fetch_assoc()` 来获取结果集中每一行的数据,并且在循环中使用了 `while` 来遍历结果集。同时,使用 `$res` 来获取结果集的行数。
相关推荐
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
var as = document.querySelectorAll('a'); for (var i = 0; i < as.length; i++) { as[i].onclick = function() { tbody.removeChild(this.parentNode.parentNode) } var subject = document.querySelector('.subject'); var name = document.querySelector('.name'); var score = document.querySelector('.score'); var info = document.querySelector('.info'); var tbody = document.querySelector('tbody'); var arr = []; info.addEventListener('submit', function (e) { e.preventDefault(); var obj = { name: name.value, subject: subject.value, score: score.value, } arr.push(obj); this.reset(); for (var i = 0; i < arr.length; i++) { var tr = document.createElement('tr'); tr.innerHTML = ${arr[i].name} ${arr[i].subject} ${arr[i].score} 删除 <button onclick="moveUp(this)">上移</button> <button onclick="moveDown(this)">下移</button> ; } tbody.appendChild(tr); }) 为什么录入name显示undef
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
h1>学生信息表格 <form class="info" autocomplete="off"> 姓名:<input type="text" class="uname" name="uname" /> 科目<input type="text" class="subject" name="subject" /> 成绩:<input type="text" class="score" name="score" /> <button class="add">录入</button> </form> 姓名 科目 成绩 操作 操作 <script> var data = [{ uname: '张三', subject: 'JavaScript', score: 100 }, { uname: '李四', subject: 'JavaScript', score: 90 }, { uname: '刘五', subject: 'JavaScript', score: 90 }]; var tbody = document.querySelector('tbody'); for (var i = 0; i < data.length; i++) { var tr = document.createElement('tr'); tbody.appendChild(tr); for (var k in data[i]) { var td = document.createElement('td'); td.innerHTML = data[i][k]; tr.appendChild(td); } var td = document.createElement('td'); td.innerHTML = '<a href="javascript:;">删除 </a>'; tr.appendChild(td); var td = document.createElement('td'); td.innerHTML = <button onclick="moveUp(this)">上移</button> <button onclick="moveDown(this)">下移</button> ; tr.appendChild(td); } var uname = document.querySelector('.uname'); var subject = document.querySelector('.subject'); var score = document.querySelector('.score'); var info = document.querySelector('.info'); var tbody = document.querySelector('tbody'); var arr = []; info.addEventListener('submit', function (e) { e.preventDefault(); var obj = { uname: uname.value, subject: subject.value, score: score.value, } arr.push(obj); this.reset(); for (var i = 0; i < arr.length; i++) { var tr = document.createElement('tr'); tr.innerHTML = ${arr[i].uname} ${arr[i].subject} ${arr[i].score} 删除 <button onclick="moveUp(this)">上移</button> <button onclick="moveDown(this)">下移</button> ; } tbody.appendChild(tr); }) var as = document.querySelectorAll('a'); for (var i = 0; i < as.length; i++) { as[i].onclick = function() { tbody.removeChild(this.parentNode.parentNode) } function moveUp(btn) { var row = btn.parentNode.parentNode; var prevRow = row.previousElementSibling; if (prevRow) { row.parentNode.insertBefore(row, prevRow); } else { row.parentNode.appendChild(row); } } } function moveDown(btn) { var row = btn.parentNode.parentNode; var nextRow = row.nextElementSibling; if (nextRow) { row.parentNode.insertBefore(nextRow, row); } else { var firstRow = row.parentNode.firstElementChild; row.parentNode.insertBefore(row, firstRow); } } </script>怎么用数组索引上下移动行
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)