- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的 JavaFX 游戏中的 Text 对象粘贴到自身上时遇到问题,我一生都无法弄清楚我做错了什么。尽管我在添加新对象之前将其删除,但我的文本对象仍然会粘贴到自身上。我相信错误应该出现在我的方法 setTextField 中,但我在下面包含了整个 GamePane 类的代码,以防万一它有帮助。预先感谢您提供的任何和所有帮助和建议! :)
只是我的 setTextField 方法:
public void setTextField() {
Text showScore = new Text("Score: " + String.valueOf(playerPointCounter)
+ "\nMisses: " + String.valueOf(gameOverCounter));
showScore.setLayoutX(25);
showScore.setLayoutY(35);
showScore.setFill(Color.WHITE);
//Font family, weight, font size
showScore.setFont(Font.font("Baskerville Old Face", FontWeight.BOLD, 20));
this.getChildren().remove(showScore);
this.getChildren().add(showScore);
} //End setTextField method
我的整个 GamePane 类:
/**
* This method adds objects to the pane, controls all animations for adding and
* moving enemies, adding and moving shots, and checking for collisions.
* NOTE: All methods for winning the game, losing the game, and such are to be
* implemented in future versions ;)
*/
package StarshipBattleDestiny;
import java.util.ArrayList;
import javafx.animation.KeyFrame;
import javafx.animation.Timeline;
import javafx.scene.layout.Pane;
import javafx.scene.paint.Color;
import javafx.scene.shape.Rectangle;
import javafx.scene.text.Font;
import javafx.scene.text.FontWeight;
import javafx.scene.text.Text;
import javafx.util.Duration;
import javax.swing.JOptionPane;
class GamePane extends Pane {
private Timeline animation;
ArrayList<LargeEnemy> largeList = new ArrayList<>();
ArrayList<SmallEnemy> smallList = new ArrayList<>();
public static ArrayList<Shot> shotList = new ArrayList<>(1);
static double GAME_WIDTH = 1000;
static double GAME_HEIGHT = 650;
public static int gameOverCounter = 0;
public static int playerPointCounter = 0;
int addToPlayerScore;
int addToMisses;
public static Launcher launcher;
Rectangle topOfGame;
static String playerName;
/**
* This constructor for the GamePane calls the method that adds the
* launcher, calls the method that adds the invisible object for the top of
* the game, and houses the animations that control when a new enemy is
* added, the rate that each SmallEnemy is moved, the rate that each
* LargeEnemy is moved, the rate that each Shot is moved, and how often the
* game will check for a collision.
*/
public GamePane() {
//Adds a launcher
addLauncher();
addTopOfGame();
//Animation to call new enemies every 10 seconds.
animation = new Timeline(new KeyFrame(Duration.seconds(5), e -> addEnemy()));
animation.setCycleCount(Timeline.INDEFINITE);
animation.play();
//Animation to move SmallEnemies
animation = new Timeline(new KeyFrame(Duration.millis(5), e -> moveSmallEnemy()));
animation.setCycleCount(Timeline.INDEFINITE);
animation.play();
//Animation to move Large Enemies
animation = new Timeline(new KeyFrame(Duration.millis(8), e -> moveLargeEnemy()));
animation.setCycleCount(Timeline.INDEFINITE);
animation.play();
//Animation to move Shots
animation = new Timeline(new KeyFrame(Duration.millis(1), e -> moveShot()));
animation.setCycleCount(Timeline.INDEFINITE);
animation.play();
this.setStyle("-fx-background-image: url(\"file:purpleSpaceBackground.jpeg\");-fx-background-size: cover");
} //End GamePane Constructor
/**
* This method adds a JOptionPane window informing the player of the
* instructions of how to play the game.
*/
public static void playerInstructionsPane() {
playerName = JOptionPane.showInputDialog("Please enter your name:");
String blankName = "";
String spaceName = " ";
while (playerName.equalsIgnoreCase(blankName)) {
playerName = JOptionPane.showInputDialog("You cannot leave your name blank.\n"
+ "Please enter your name:");
}
while (playerName.equalsIgnoreCase(spaceName)) {
playerName = JOptionPane.showInputDialog("A space is not a valid name.\n"
+ "Please enter your name:");
}
while (playerName.length() < 3) {
playerName = JOptionPane.showInputDialog("Player's name must be 3 characters or more in length.\n"
+ "Please enter your name:");
}
String playerInstructionsMsg = "You are the captain of the Starship Destiny at the bottom of the screen.\n"
+ "Fire your Forward Guns at the enemy ships above you with the Space Bar.\n"
+ "The larger Asgard Ships are worth 10 points, while the smaller Kino Drones are worth twice that at 20 points.\n"
+ "It takes 500 points to win but only 10 misses to lose.\n\n"
+ "Winning the game earns you the coordinates to your enemy's base.\n\n"
+ "You can press the P button at any time to either surrender or show your enemies mercy.\n"
+ "This will also save your score and add it to the high scores, assuming it is one.\n"
+ "\n"
+ "Good Luck!";
JOptionPane.showMessageDialog(null, playerInstructionsMsg, "How To Play", JOptionPane.INFORMATION_MESSAGE);
} //end playerInstructionsPane method
/**
* When this method is called it begins playing the animations.
*/
public void play() {
animation.play();
} //End play method
/**
* When this method is called it stops playing the animations.
*/
public void stop() {
animation.stop();
} //End stop method
/**
* When this method is called it pauses the animations that are playing.
*/
public void pause() {
animation.pause();
} //End pause method
/**
* This method adds an invisible rectangle to the top that ends the game
* when it is hit 10 times... (aka: when the player misses 10 times).
*/
public void addTopOfGame() {
topOfGame = new Rectangle(); //Set slightly above game view so shot will be offscreen before it dissapears.
topOfGame.setX(0);
topOfGame.setY(0);
topOfGame.setHeight(10);
topOfGame.setWidth(1000);
topOfGame.setFill(Color.TRANSPARENT);
this.getChildren().add(topOfGame);
addToMisses = 1;
} //End addTopOfGame methpd
/**
* This method adds a new Launcher to the pane.
*/
public void addLauncher() {
launcher = new Launcher();
launcher.setWidth(70);
launcher.setHeight(103);
launcher.setX((GAME_WIDTH * 0.5) - (launcher.getWidth() * 0.5) + 10);
launcher.setY(GAME_HEIGHT - 100);
this.getChildren().add(launcher);
} //End addLauncher method
/**
* This method adds new enemies. It has a random variable that generates a
* number between 0 and 100. If this random variable is less than 60 a new
* LargeEnemy is created and added to the pane, and if the random variable
* is higher than 60 it crates a new SmallEnemy and adds it to the pane.
* This means that there is a 60% chance of a new LargeEnemy being created
* and a 40% chance of a new SmallEnemy being created.
*/
public void addEnemy() {
int random = (int) (0 + Math.random() * 100);
if (random < 60) { //60:40 chance LargeEnemy:SmallEnemy
addToPlayerScore = 10;
LargeEnemy newLargeEnemy = new LargeEnemy();
newLargeEnemy.setWidth(182);
newLargeEnemy.setHeight(102);
newLargeEnemy.setX(0);
newLargeEnemy.setY(60 + Math.random() * 200);
newLargeEnemy.setVisible(true);
largeList.add(newLargeEnemy);
this.getChildren().add(newLargeEnemy);
//countdownToLargeCollisionCheck();
} //End boolean if statement to add a newLargeEnemy
else {
addToPlayerScore = 20;
SmallEnemy newSmallEnemy = new SmallEnemy();
newSmallEnemy.setX(0);
newSmallEnemy.setY(60 + Math.random() * 250);
newSmallEnemy.setWidth(60);
newSmallEnemy.setHeight(60);
newSmallEnemy.setVisible(true);
smallList.add(newSmallEnemy);
this.getChildren().add(newSmallEnemy);
//countdownToSmallCollisionCheck();
} //End boolean else statemet to add a newSmallEnemy
} //End addEnemy method
/**
* This method adds a new Shot to the screen. It is called whenever the
* player hits the Space Bar.
*/
public void fire() {
if (shotList.isEmpty()) {
Shot newShot = new Shot();
newShot.setX(GAME_WIDTH * 0.5);
newShot.setY(launcher.getY() - launcher.getHeight() - 30);
newShot.setWidth(18);
newShot.setHeight(134);
newShot.setVisible(true);
shotList.add(newShot);
this.getChildren().add(newShot);
}
else {
//Don't add a new shot.
}
} //End fire method
/**
* This method sets how much each SmallEnemy will be moved each time the
* animation timer calls the method, as well as removing the SmallEnemy if
* it's x-axis value is greater than or equal to the width of the game + the
* width of a SmallEnemy.
*/
public void moveSmallEnemy() {
for (int i = 0; i < smallList.size(); i++) {
SmallEnemy moveSmall = smallList.get(i);
double x = moveSmall.getX();
double smallDX = 1;
double removeSmall = GAME_WIDTH + moveSmall.getWidth();
if (x >= removeSmall) {
smallList.remove(i);
} //end boolean if statement to change direction
x += smallDX;
moveSmall.setX(x);
} //end for loop
} //End moveSmallEnemy method
/**
* This method sets how much each LargeEnemy will be moved each time the
* animation timer calls the method, as well as removing the LargeEnemy if
* it's x-axis value is greater than or equal to the width of the game + the
* width of a LargeEnemy.
*/
public void moveLargeEnemy() {
for (int i = 0; i < largeList.size(); i++) {
LargeEnemy moveLarge = largeList.get(i);
double x = moveLarge.getX();
double largeDX = 1;
double removeLarge = GAME_WIDTH + moveLarge.getWidth();
if (x >= removeLarge) {
largeList.remove(i);
} //end boolean if statement to change direction
x += largeDX;
moveLarge.setX(x);
} //end for loop
} //End moveLargeEnemy method
/**
* This method sets how much each Shot will be moved each time the animation
* timer calls the method.
*/
public void moveShot() {
if (shotList.isEmpty()) {
return;
}
for (int i = 0; i < shotList.size(); i++) {
Shot shot = shotList.get(i);
double y = shot.getY();
double dy = 0.21;
y -= dy;
shot.setY(y);
} //End for loop
collisionCheckTimeline();
} //End moveShot method
/**
* When this method is called it runs the animations to check for collisions
* with each SmallEnemy, each LargeEnemy, and with the invisible object at
* the top of the game.
*/
public void collisionCheckTimeline() {
animation = new Timeline(new KeyFrame(Duration.millis(1), e -> checkCollisionSmall()));
animation.setCycleCount(1);
animation.play();
animation = new Timeline(new KeyFrame(Duration.millis(1), e -> checkCollisionLarge()));
animation.setCycleCount(1);
animation.play();
animation = new Timeline(new KeyFrame(Duration.millis(1), e -> checkTopCollision()));
animation.setCycleCount(1);
animation.play();
} //End smallCollisionTimeline method
/**
* This method checks for collisions with each SmallEnemy.
*/
public void checkCollisionSmall() {
//This segment of code checks for collisions with each SmallEnemy.
for (int i = 0; i < shotList.size(); i++) {
Shot tempShot = shotList.get(i);
tempShot.setVisible(true);
for (int j = 0; j < smallList.size(); j++) {
SmallEnemy tempSmall = smallList.get(i);
tempSmall.setVisible(true);
if (tempShot.isVisible() && tempSmall.isVisible()) {
if (tempShot.getBoundsInLocal().intersects(tempSmall.getBoundsInLocal())) {
tempShot.setVisible(false);
tempSmall.setVisible(false);
smallList.remove(j);
shotList.remove(i);
setScore();
} //End inner boolean if statement
} //End of outer boolean if statement
} //End inner for loop
} //End outer for loop
} //End checkCollisionSmall method
/**
* This method checks for collisions with each LargeEnemy.
*/
public void checkCollisionLarge() {
//This segment of code checks for collisions with each LargeEnemy.
for (int i = 0; i < shotList.size(); i++) {
Shot tempShot = shotList.get(i);
tempShot.setVisible(true);
for (int j = 0; j < largeList.size(); j++) {
LargeEnemy tempLarge = largeList.get(j);
tempLarge.setVisible(true);
if (tempShot.isVisible() && tempLarge.isVisible()) {
if (tempShot.getBoundsInParent().intersects(tempLarge.getBoundsInParent())) {
tempShot.setVisible(false);
tempLarge.setVisible(false);
largeList.remove(j);
shotList.remove(i);
setScore();
} //End inner boolean if statement
} //End outer boolean if statement
} //End inner for loop
} //End outer for loop
} //End checkCollisionLarge method
/**
* This method checks for a collision with the invisible rectangle at the
* top of the screen.
*/
public void checkTopCollision() {
//This segment of code checks for collisions with the invisible topOfGame Rectangle object.
for (int i = 0; i < shotList.size(); i++) {
Shot tempShot = shotList.get(i);
tempShot.setVisible(true);
if (tempShot.isVisible() && topOfGame.isVisible()) {
if (tempShot.getBoundsInParent().intersects(topOfGame.getBoundsInParent())) {
tempShot.setVisible(false);
shotList.remove(i);
setMisses();
} //end inner boolean if statement
} //end outer boolean if statement
} //end for loop
} //End checkTopCollision method
/**
* This method updates the counter for the player's points.
*/
public void setScore() {
//int pointsToWin = 500;
playerPointCounter += addToPlayerScore;
System.out.println("Score updated: " + playerPointCounter);
setTextField();
//If the player gets a point amount within the given range the winGame and stop method are called.
if (playerPointCounter > 499 && playerPointCounter < 511) {
winGame();
stop();
}
} //End setScore method
/**
* This method updates the counter for the player's misses.
*/
public void setMisses() {
int missesToLose = 10;
gameOverCounter += addToMisses;
System.out.println("Misses Updated: " + gameOverCounter);
setTextField();
//If the player gets the number of points designated then the loseGame method is called.
if (gameOverCounter == missesToLose) {
loseGame();
}
while(gameOverCounter == missesToLose) {
stop();
}
} //End setMisses method
/**
* This method updates the Text object with the new score information, removes
* the old TextField from the Pane, and adds the new Text object with the
* updated score to the pane. It is called every time a collision is
* detected and the player's score counter or miss counter is updated.
*/
public void setTextField() {
Text showScore = new Text("Score: " + String.valueOf(playerPointCounter)
+ "\nMisses: " + String.valueOf(gameOverCounter));
showScore.setLayoutX(25);
showScore.setLayoutY(35);
showScore.setFill(Color.WHITE);
//Font family, weight, font size
showScore.setFont(Font.font("Baskerville Old Face", FontWeight.BOLD, 20));
this.getChildren().remove(showScore);
this.getChildren().add(showScore);
} //End setTextField method
/**
* This method determines if the player loses the game. The player loses the
* game when they miss a target 10 times. When the game is lost a
* JOptionPane window displays telling them the game is over and how many
* points they had when they lost. This method also stops all animations.
*/
public static void loseGame() {
String playerLosesMsg = "You Missed 10 times and Lost!\n\n"
+ "Your Score: " + playerPointCounter;
JOptionPane.showMessageDialog(null, playerLosesMsg, "Game Over!", JOptionPane.INFORMATION_MESSAGE);
mainScoreControl();
System.exit(10);
} //End loseGame method
/**
* This method determines if the player wins the game. The player wins the
* game when they earn 500 points. When the game is won a JOptionPane
* window displays telling them they won the game, how many points they
* had at the end, how many misses they had, and the coordinates for the
* final location.
*/
public static void winGame() {
final String FINAL_COORDS = "N 39 00.000 W 084 00.000";
String playerWinsMsg = "You Win!\n\n"
+ "Your Score: " + playerPointCounter + "\n"
+ "Misses: " + gameOverCounter + "\n\n"
+ "Final Coordinates for GC00000:\n"
+ FINAL_COORDS;
JOptionPane.showMessageDialog(null, playerWinsMsg, "Congratulations!", JOptionPane.INFORMATION_MESSAGE);
//mainScoreControl(); REMOVED
} //End winGame method
/**
* When the player presses the "P" button this method is called.
* It displays one of two messages based on how many points the player has
* at the time it is pressed. One message the player accepts their loss and
* for the other the game accepts their loss. Either way the player's
* point total and total number of misses are displayed and the
* mainScoreControl method is called.
*/
public static void endGame() {
if (playerPointCounter <= 499) {
String surrenderMsg = "Your surrender has been accepted, Captain!\n\n"
+ "Your Score: " + playerPointCounter + "\n"
+ "Misses: " + gameOverCounter;
JOptionPane.showMessageDialog(null, surrenderMsg, "Surrender Accepted", JOptionPane.INFORMATION_MESSAGE);
}
else {
String endGameMsg = "We accept our defeat... for now!\n\n"
+ "Your Score: " + playerPointCounter + "\n"
+ "Misses: " + gameOverCounter;
JOptionPane.showMessageDialog(null, endGameMsg, "Game Over!", JOptionPane.INFORMATION_MESSAGE);
}
mainScoreControl();
//System.exit(1);
} //End endGame method
/**
* This method creates a new instance of HighScoreManager, adds the player's
* score to the ArrayList of high scores in the HSM Class via its addScore
* method, and outputs that information in a JOptionPane window.
*/
public static void mainScoreControl() {
HighScoreManager highScoreManager = new HighScoreManager();
highScoreManager.addScore(playerName,playerPointCounter);
System.out.print(highScoreManager.getHighscoreString());
String highScoreMsg = highScoreManager.getHighscoreStringMsg();
JOptionPane.showMessageDialog(null, highScoreMsg, "High Scores", JOptionPane.INFORMATION_MESSAGE);
System.exit(1);
} //End mainScoreControl method
/**
* Called when Control-Alt-P is pressed so I can view the high scores without accidentally effecting anything.
*/
public static void showHighScores() {
HighScoreManager highScoreManager = new HighScoreManager();
String highScoreMsg = highScoreManager.getHighscoreStringMsg();
JOptionPane.showMessageDialog(null, highScoreMsg, "High Scores", JOptionPane.INFORMATION_MESSAGE);
} //End showHighScores method
public static void keyTest() {
CacheManager cacheManager = new CacheManager();
String thing = cacheManager.getCoordinateString();
System.out.println(thing);
}
public static void mainCacheControl() {
CacheManager cacheManager = new CacheManager();
String newGcCode;
String newCoordinates;
String newAdminPassword;
String userEnteredPassword = JOptionPane.showInputDialog("Please Enter Your Admin Password: ");
String adminPassword = cacheManager.getAdminPasswordString();
if (userEnteredPassword.equals(adminPassword)) {
newGcCode = changeGcCode();
newCoordinates = changeCoordinates();
newAdminPassword = changeAdminPassword();
cacheManager.addCacheInfo(newAdminPassword, newGcCode, newCoordinates);
String newCacheInfoMsg = "Your new GC Code is: " + newGcCode + "\n" +
"Your new Coordinates are: " + newCoordinates + "\n" +
"Your new Admin Password is: " + newAdminPassword;
JOptionPane.showMessageDialog(null, newCacheInfoMsg, "[ADMIN] Review New Cache Info", JOptionPane.INFORMATION_MESSAGE);
}
else {
String incorrectAdminPasswordMsg = "You incorrectly entered the Admin Password. Terminating Program.";
JOptionPane.showMessageDialog(null, incorrectAdminPasswordMsg, "Incorrect Admin Password Entered", JOptionPane.INFORMATION_MESSAGE);
System.exit(666);
}
System.exit(1);
} //End mainScoreControl method
public static String changeGcCode() {
CacheManager cacheManager = new CacheManager();
String gcCode;
String gcChangeMsg = "Would you like to change the GC Code?";
int changeGcCode = JOptionPane.showConfirmDialog(null, gcChangeMsg, "[ADMIN] GC Code Options", JOptionPane.YES_NO_OPTION);
if (changeGcCode == JOptionPane.YES_OPTION) {
gcCode = JOptionPane.showInputDialog("Please Enter the New GC Code: ");
}
else {
if (cacheManager.isListEmpty() == false) {
gcCode = cacheManager.getCacheGcCodeString();
}
else {
CacheInfo cacheInfo = new CacheInfo();
gcCode = cacheInfo.getGcCode();
}
}
return gcCode;
} //End changeGcCode method
public static String changeCoordinates() {
CacheManager cacheManager = new CacheManager();
String finalCoordinates;
String coordChangeMsg = "Would you like to change the Coordinates?";
int changeCoords = JOptionPane.showConfirmDialog(null, coordChangeMsg, "[ADMIN] Coordinate Options", JOptionPane.YES_NO_OPTION);
if (changeCoords == JOptionPane.YES_OPTION) {
finalCoordinates = JOptionPane.showInputDialog("Please Enter the New Coordinates: ");
}
else {
if (cacheManager.isListEmpty() == false) {
finalCoordinates = cacheManager.getCoordinateString();
}
else {
CacheInfo cacheInfo = new CacheInfo();
finalCoordinates = cacheInfo.getFinalCoordinates();
}
}
return finalCoordinates;
} //End changeCoordinates method
public static String changeAdminPassword() {
CacheManager cacheManager = new CacheManager();
String adminPassword;
String coordChangeMsg = "Would you like to change the Admin Password?";
int changeAdminPassword = JOptionPane.showConfirmDialog(null, coordChangeMsg, "[ADMIN] Admin Password Options", JOptionPane.YES_NO_OPTION);
if (changeAdminPassword == JOptionPane.YES_OPTION) {
adminPassword = JOptionPane.showInputDialog("Please Enter the New Admin Password: ");
}
else {
if (cacheManager.isListEmpty() == false) {
adminPassword = cacheManager.getAdminPasswordString();
}
else {
CacheInfo cacheInfo = new CacheInfo();
adminPassword = cacheInfo.getAdminPassword();
}
}
return adminPassword;
}
} //End of GamePane Class
最佳答案
为了说明问题所在,让我们说得更简单:
public void setTextField() {
Text showScore = new Text("Score: "+String.valueOf(playerPointCounter));
this.getChildren().remove(showScore);
this.getChildren().add(showScore);
}
问题是这样的:this.getChildren().remove(showScore);
尝试删除您刚刚创建的新showScore
对象,该对象甚至没有打开 Pane 中,它不会删除以前的 Text
节点,并且您将在每次调用时添加一个新实例。
第一个解决方案是删除找到的所有 Text
实例:
public void setTextField() {
Text showScore = new Text("Score: "+String.valueOf(playerPointCounter));
this.getChildren().removeIf(Text.class::isInstance);
this.getChildren().add(showScore);
}
注意 removeIf
需要 Java 8。由于这不是最佳解决方案,因此我不会讨论 Java 7 版本。它还会删除所有其他可能的文本,因此也许您可以为文本设置一个 id
并删除具有该 id 的节点。
第二个选项:在类中创建一个全局 Text
节点:
final Text showScore;
public GamePane() {
...
showScore=new Text();
this.getChildren().add(showScore);
}
现在简单地更新它的文本属性:
public void setTextField() {
showScore.setText("Score: " + String.valueOf(playerPointCounter)
+ "\nMisses: " + String.valueOf(gameOverCounter));
showScore.setLayoutX(25);
showScore.setLayoutY(35);
showScore.setFill(Color.WHITE);
//Font family, weight, font size
showScore.setFont(Font.font("Baskerville Old Face", FontWeight.BOLD, 20));
}
请注意,每次调用 setTextfield()
时,您都会对控件进行布局,因此可以将其移至构造函数。
第三个选项:创建节点,并使用绑定(bind)到它的一些属性。仅调用一次 setTextField()
来创建绑定(bind)并布局节点。然后,您只需在需要时增加计数器(例如 incrementPointCounter()
):
private final Text showScore=new Text();
private final IntegerProperty playerPointCounter=new SimpleIntegerProperty();
private final IntegerProperty gameOverCounter=new SimpleIntegerProperty();
public void setTextField() {
showScore.textProperty().bind(Bindings.concat("Score: ")
.concat(playerPointCounter.asString())
.concat("\nMisses: ").concat(gameOverCounter.asString()));
showScore.setLayoutX(25);
showScore.setLayoutY(35);
showScore.setFill(Color.WHITE);
//Font family, weight, font size
showScore.setFont(Font.font("Baskerville Old Face", FontWeight.BOLD, 20));
this.getChildren().add(showScore);
}
public void incrementPointCounter(){
playerPointCounter.set(playerPointCounter.get()+1);
}
关于JavaFX 文本粘贴在其自身之上,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28128941/
因此,我试图在网站主体中创建导航和页脚,但 particle.js 不断覆盖这些元素。我试过 z-index 但它没有显示出来。 particle.js 不允许我触摸我的导航栏或页脚。会很感激一些帮助
我正在为我的类(class)建立一个美食车网站。我想要有一个盘子的图像,然后一旦它被点击就会有一个不同的食物图像出现在它上面。我想知道可以使用哪种 javascript 或 else/if 语句来实现
我目前正在做一个元素,我有两张人体图像,正面和背面。图像设置为 height: 80vh。我的问题是:我一直在使用 bootstrap 在屏幕较宽时使图像并排流动,在屏幕高时使图像相互叠加,使用 co
有没有办法将“处理...”语言放在 DataTable 对象的顶部而不是垂直中间?如果我有一张长 table ,它会隐藏在页面之外,因为它的默认位置在中间。 $('#example').dataTab
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
问题 我有一个表单,一旦用户填写并提交,我希望在表单上弹出一条消息,显示“现在坐下来放松一下吧……”。理想情况下,我希望此消息上有一个按钮表示“确定”。 到目前为止我有什么? 通过 ajax post
我想在 div 之上制作一个菜单,所以文本基本上位于它之上(参见示例)。我想在同一个 div 中包含菜单的文本,所以 html 是这样的: Portfolio |
我想在 div 之上制作一个菜单,所以文本基本上位于它之上(参见示例)。我想在同一个 div 中包含菜单的文本,所以 html 是这样的: Portfolio |
我想创建这样的布局: 我有 3 个不同的图像:背景、白色方 block 和 V 形符号。 当我希望盒子从一侧移动到另一侧时,如何将它们定位为照片中的位置 当 onClick 被触发时。 我已经尝试过:
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 关于您编写的代码问题的问题必须在问题本身中描述具体问题 — 并且包括有效代码 以重现它。参见 SSC
我正在尝试获取鼠标当前悬停的元素并将其返回。根据我迄今为止从研究中收集到的信息,这是执行此操作的代码: document.getElementById('theTable').onmouseo
首先,我想说声抱歉,但我在设计 Android 应用程序时遇到了问题 :D我希望该按钮位于 ListView 下方。实际上该按钮位于 ListView 上方并隐藏了下部区域。我该如何解决? scree
我正在尝试使用 Swiperefreshlayout,它工作得很好,但我需要知道用户何时位于我的 Activity 顶部。我正在阅读这个,我发现了一个名为“setOnScrollListener”的方
我想有两个按钮像页脚一样固定在底部屏幕上,其他 View 不会传递它或在两个按钮上重叠。它只会一直停留在底部。对不起我的英语不好。请帮我。顺便说一句,我不能发布图片,所以它需要 10 个声誉,这就是我
我在所有页面上都有一个由 JavaScript 创建的下拉菜单,有些列最多有 20 个元素。在 Mozilla 浏览器中,此下拉列表显示在所有内容的最上方,但在 Internet Explorer 中
如果我直接在框架上绘画,它显示得很好,但船不会出现在面板顶部... package MoonBlast; import java.awt.BorderLayout; import java.awt.
我已经着手设置我的 JFrame 的背景图像,但现在我的组件(我假设)卡在它后面。我已经尝试阅读有关顶级容器的内容,但我就是无法理解它 T_T。有人有主意吗 ?也许我需要找到另一种方式来设置背景图片?
我有一个 UIView (A),它以纵向模式显示并附加了一个 UIButton。当用户单击按钮时,第二个 UIView (B) 被初始化并显示为 UIView A 顶部的模态视图。 是否可以将第二个
我对这件事束手无策。 我有几个 div。它们都有一个向下的箭头。它应该居中在中间,棕色线上和所有东西的顶部。最后一个 div 也应该有箭头。我尝试了 z-index、绝对和相对定位,但没有任何效果。
我正在尝试使图像出现在父 div 之外,这样图像看起来就好像位于 div 上而不增加父 div 的高度。但是,无论我尝试过什么,图像都会被父 div 截断并且不会显示所有内容。 我有一个 js fid
我是一名优秀的程序员,十分优秀!